C語言之雙向連結串列
1,雙向連結串列簡介。
雙向連結串列也叫雙連結串列,是連結串列的一種,它的每個資料結點中都有兩個指標,分別指向直接後繼和直接前驅。所以,從雙向連結串列中的任意一個結點開始,都可以很方便地訪問它的前驅結點和後繼結點。一般我們都構造雙向迴圈連結串列。
2,例子要求:
完成雙向連結串列的插入、刪除以及查詢,將學生管理系統使用的陣列,以雙向連結串列的方式實現,能夠支援無限制的學生人數的增刪改查以及儲存。
3,程式碼實現。
#include
#include
#include
#include
typedef struct Student{
char name[20];
int score;
char phoneNum[14];
} str_student;
typedef struct Node{
str_student data;
struct Node *prior; //指向前驅結點
struct Node *next; //指向後繼結點
}Node, *DLinkList;
// 初始化一個學生連結串列
DLinkList initDouLinkList()
{
Node *L,*p,*r;
char name[20];
char phone[14];
int score;
L = (Node *)malloc(sizeof(Node));
L->next = NULL;
r = L;
r->next = NULL;
while(1)
{
p = (Node *)malloc(sizeof(Node));
printf("input name is out exit,input student name:\n");
scanf("%s",name);
if (strcmp(name,"out")==0)
{
break;
}
strcpy(p->data.name, name);
printf("input student score:");
scanf("%d",&score);
p->data.score = score;
printf("input student phone:");
scanf("%s",phone);
strcpy(p->data.phoneNum, phone);
p->next = r->next;
r->next = p;
r = p;
}
r->next = NULL;
return L;
}
//新增學生資訊
DLinkList insertDouLinkListStuent(DLinkList L,int i,char *name, int score,char *phonenum)
{
DLinkList p,s;
p = L->next;
int tempi;
for(tempi = 1;tempi < i-1; tempi++)
p = p->next;
s = (Node *)malloc(sizeof(Node));
s->data.score = score;
strcpy(s->data.name,name);
strcpy(s->data.phoneNum,phonenum);
s->next = p->next;
p->next->prior = s;
s->prior = p;
p->next = s;
return L;
}
// 查詢學生資訊
int findDouLinkListStudent(DLinkList L,char *name)
{
DLinkList p;
p = L->next;
int i = 1;
while(p != NULL && (strcmp(p->data.name, name)!=0))
{
++i;
p = p->next;
}
if(p == NULL)
return 0;
else return i;
}
// 移除一個學生
DLinkList removeDouLinkListStudent(DLinkList L,char *name)
{
int tempi = 1;
DLinkList p;
p = L->next;
int i =findDouLinkListStudent(L,name);
while((tempi++) != i && p != NULL)
{
p = p->next;
}
if(p == NULL)
printf("no list \n");
else if(p->next == NULL)
{
p->prior->next = NULL;
free(p);
}
else
{
p->prior->next = p->next;
p->next->prior = p->prior;
free(p);
}
return L;
}
// 鋪助列印資訊
void printfInfo(DLinkList L)
{
DLinkList p;
p = L->next;
while (p!=NULL)
{
printf("student name %s\n",p->data.name);
printf("student name %d\n",p->data.score);
printf("student name %s\n",p->data.phoneNum);
p=p->next;
}
}
void main ()
{
char name2[20]="hanmeimei";
char phone2[14]="13612345678";
DLinkList L =initDouLinkList();
// 2.1 初始化學生雙向連結串列資料
insertDouLinkListStuent(L,1,name2,99,phone2);
printfInfo(L);
// 2.2 查詢學生zhangsan
findDouLinkListStudent(L,'zhangsan');
printfInfo(L);
// 2.3 刪除學生zhangsan
removeDouLinkListStudent(L,'zhangsan');
printfInfo(L);
// 2.4 新增學生zengteng
insertDouLinkListStuent(L,9,'zengteng',89,'13643345667');
printfInfo(L);
}
原部落格地址: http://blog.itpub.net/26230597/viewspace-1386602/
原作者:黃杉 (mchdba)
----------------------------------------------------------------------------------------------------------------
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/26230597/viewspace-1386602/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- C語言之單向連結串列C語言
- 雙向連結串列介面設計(C語言)C語言
- 雙向連結串列
- 詳解雙向連結串列的基本操作(C語言)C語言
- C++實現通用雙向連結串列C++
- 【c# .net】雙向連結串列( LinkedList )C#
- C語言資料結構:雙向連結串列的增刪操作C語言資料結構
- javascript中的連結串列結構—雙向連結串列JavaScript
- 資料結構--陣列、單向連結串列、雙向連結串列資料結構陣列
- 雙向迴圈連結串列基本操作的實現(C語言)C語言
- 實現雙向連結串列
- JAVA基礎:語言中連結串列和雙向連結串列的實現(轉)Java
- C 語言使用非迴圈雙向連結串列實現佇列佇列
- 資料結構——雙向連結串列資料結構
- 資料結構:雙向連結串列資料結構
- C語言資料結構:雙向迴圈連結串列的增刪操作C語言資料結構
- 結構與演算法(03):單向連結串列和雙向連結串列演算法
- Go實現雙向連結串列Go
- java實現雙向連結串列Java
- c/c++ 線性表之雙向迴圈連結串列C++
- 資料結構學習(C++)——雙向連結串列 (轉)資料結構C++
- 雙向迴圈連結串列及各功能函式設計(C語言)函式C語言
- 資料結構實驗之連結串列九:雙向連結串列資料結構
- 資料結構之雙向連結串列資料結構
- Java雙向連結串列的實現Java
- 複習下C 連結串列操作(雙向迴圈連結串列,查詢迴圈節點)
- C語言單向連結串列的增刪操作C語言
- 資料結構與演算法——連結串列 Linked List(單連結串列、雙向連結串列、單向環形連結串列-Josephu 問題)資料結構演算法
- 畫江湖之資料結構【第一話:連結串列】雙向連結串列資料結構
- 畫江湖之資料結構 [第一話:連結串列] 雙向連結串列資料結構
- 把BST轉換為雙向連結串列
- 雙向連結串列的建立及基本操作
- 雙向連結串列的功能實現(初版
- c語言單向連結串列逆轉實現方法C語言
- 單向迴圈連結串列介面設計(C語言)C語言
- Linux 核心資料結構:雙向連結串列Linux資料結構
- 雙向連結串列————查詢、刪除、插入結點
- 資料結構(雙向連結串列的實現)資料結構