C語言數(shù)據(jù)結(jié)構(gòu)之雙向循環(huán)鏈表的實(shí)例
更新時(shí)間:2017年06月27日 08:44:28 投稿:lqh
這篇文章主要介紹了C語言數(shù)據(jù)結(jié)構(gòu)之雙向循環(huán)鏈表的實(shí)例的相關(guān)資料,需要的朋友可以參考下
數(shù)據(jù)結(jié)構(gòu)之雙向循環(huán)鏈表
實(shí)例代碼:
#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("請(qǐng)輸入您想要?jiǎng)?chuàng)建鏈表結(jié)點(diǎn)的個(gè)數(shù):len = ");
scanf("%d", &length);
for(i = 0;i < length;i++){
printf("請(qǐng)輸入第%d個(gè)結(jié)點(diǎn)的值:", 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;
}
}
}
}
實(shí)現(xiàn)效果:

感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
數(shù)據(jù)結(jié)構(gòu)之堆的具體使用
本文主要介紹了數(shù)據(jù)結(jié)構(gòu)之堆的具體使用,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02
C/C++關(guān)于實(shí)現(xiàn)CAN信號(hào)的獲取方法
這篇文章主要介紹了C/C++關(guān)于實(shí)現(xiàn)CAN信號(hào)的獲取方法,標(biāo)準(zhǔn)的CAN 數(shù)據(jù)為8字節(jié),即64位,但是CAN FD的最大數(shù)據(jù)可為64字節(jié),為512位,其中的幀ID分為標(biāo)準(zhǔn)幀和擴(kuò)展幀,其中用11位標(biāo)準(zhǔn)幀,用29位表示擴(kuò)展幀2023-02-02
C++一個(gè)函數(shù)如何調(diào)用其他.cpp文件中的函數(shù)
這篇文章主要介紹了C++一個(gè)函數(shù)如何調(diào)用其他.cpp文件中的函數(shù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02
c語言程序設(shè)計(jì)文件操作方法示例(CreateFile和fopen)
c主要的文件操作函數(shù)有:CreateFile,CloseHandle,ReadFile,WriteFile,SetFilePointer,GetFileSize。其中的讀寫操作是以字符為單位,獲得文件大小也是以字符為單位。2013-12-12

