C語言數(shù)據(jù)結(jié)構(gòu)之雙向循環(huán)鏈表的實例
數(shù)據(jù)結(jié)構(gòu)之雙向循環(huán)鏈表
實例代碼:
#include <stdlib.h>
#include <stdio.h>
#include <malloc.h>
typedef struct Node{
struct Node *pNext;
int data;
struct Node *prior;
} NODE,*PNODE;
PNODE CreatList();
void TreNode(PNODE pHead);
bool isEmpty(PNODE pHead);
int getCount(PNODE pHead);
bool insertNode (PNODE pHead,int pos,int val);
bool detNode (PNODE pHead,int pos,int *pVal);
void sort(PNODE pHead);
int main(){
int val;
PNODE pHead = NULL;
pHead = CreatList();
TreNode(pHead);
printf("鏈表不為空!\n");
printf("鏈表不為空!\n");
if(insertNode(pHead, 4, 7))
printf("插入成功!插入的元素為:%d\n", 7);
else
printf("插入失敗!\n");
//重新遍歷鏈表
TreNode(pHead);
//刪除元素測試
if(detNode(pHead, 3, &val))
printf("元素刪除成功!刪除的元素是:%d\n", val);
else
printf("元素刪除失敗!\n");
TreNode(pHead);
return 0 ;
}
PNODE CreatList(){
int i ;
int val;
int length;
PNODE pHead = (PNODE)malloc(sizeof(NODE));
if(NULL==pHead)
{
printf("創(chuàng)建鏈表失??!\n");
exit(-1);
}
pHead->pNext = NULL;
pHead->prior = NULL;
PNODE pTail = pHead;
printf("請輸入您想要創(chuàng)建鏈表結(jié)點的個數(shù):len = ");
scanf("%d", &length);
for(i = 0;i < length;i++){
printf("請輸入第%d個結(jié)點的值:", i+1);
scanf("%d", &val);
PNODE pnew = (PNODE)malloc(sizeof(NODE));
if(NULL==pHead)
{
printf("創(chuàng)建鏈表失?。n");
exit(-1);
}
pnew->data = val;
// pTail->pNext = pnew;
pTail->pNext = pnew;
pnew->prior = pTail;
pnew->pNext = pHead;
pHead->prior = pnew;
pTail = pnew;
}
return pHead;
}
void TreNode(PNODE pHead){
PNODE p = pHead->pNext;
while(p!= pHead ){
printf("%d",p->data);
p = p->pNext;
}
printf("\n");
return ;
}
bool isEmpty(PNODE pHead){
if(NULL==pHead->pNext)
return true;
else
return false;
}
int getCount(PNODE pHead)
{
int i =0 ;
PNODE p = pHead->pNext;
while(NULL != p){
p = p->pNext;
i++;
}
return i ;
}
bool insertNode (PNODE pHead,int pos,int val){
int i = 0;
// PNODE p = pHead;
PNODE p =pHead;
while(NULL !=p && i<pos-1){
p = p->pNext;
i++;
}
if(NULL == p || i>pos-1)
{
return false;
}
scanf("%d", &val);
PNODE pNew = (PNODE)malloc(sizeof(NODE));
if(NULL==pNew)
{
printf("創(chuàng)建鏈表失??!\n");
exit(-1);
}
pNew ->data = val;
PNODE q = p->pNext;
p->pNext = pNew;
pNew->prior = p;
pNew->pNext = q;
return true;
}
bool detNode (PNODE pHead,int pos,int *pVal){
int i = 0;
// PNODE p = pHead;
PNODE p = pHead;
while(NULL !=p && i<pos-1){
p = p->pNext;
i++;
}
if(NULL == p || i>pos-1)
{
return false;
}
*pVal = p->pNext->data;
PNODE q = p->pNext;
p->pNext = p->pNext->pNext;
free(q);
q = NULL;
return true;
}
void sort(PNODE pHead){
int i,j,k,t;
k = getCount(pHead);
PNODE p,q;
for(i = 0,p=pHead->pNext;i < k-1;i++,p = p->pNext)
{
for(j = i+1,q = p->pNext;j<k;j++,q = q->pNext){
if(p->data > q->data ){
t = p->data;
p->data = q->data;
q->data = t;
}
}
}
}
實現(xiàn)效果:
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
上一篇:C++ 數(shù)據(jù)結(jié)構(gòu)線性表-數(shù)組實現(xiàn)
欄 目:C語言
本文標題:C語言數(shù)據(jù)結(jié)構(gòu)之雙向循環(huán)鏈表的實例
本文地址:http://www.jygsgssxh.com/a1/Cyuyan/1418.html
您可能感興趣的文章
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用函數(shù)刪除字符
- 04-02c語言的正則匹配函數(shù) c語言正則表達式函數(shù)庫
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言中對數(shù)函數(shù)的表達式 c語言中對數(shù)怎么表達
- 04-02c語言用函數(shù)寫分段 用c語言表示分段函數(shù)
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排序法函數(shù)
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段函數(shù)
- 04-02C語言中怎么打出三角函數(shù) c語言中怎么打出三角函數(shù)的值
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求階乘


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機閱讀
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10delphi制作wav文件的方法
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開發(fā)環(huán)境設置
- 01-11ajax實現(xiàn)頁面的局部加載
- 04-02jquery與jsp,用jquery
- 01-10C#中split用法實例總結(jié)
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文


