首页 > 代码库 > [转载(有删改)]单链表
[转载(有删改)]单链表
申明:
转载 http://www.cnblogs.com/Romi/category/348304.html
链表:使用节点存储数据元素,节点的地址可以连续也可以不连续
单链表中一个节点的组成:数据域+指针域,指针于中存放的是是一个指针,指向下一个节点的地址。
内容包括:单链表的定义/初始化/查找节点/插入节点/删除节点
1 #include<stdio.h> 2 #include<stdlib.h> 3 #include<malloc.h> 4 5 //定义单链表 6 struct node{ 7 char data; 8 struct node *next; 9 }; 10 typedef struct node linkList; 11 12 /*单链表结构 13 p 0x804b008 14 *0x804b008 15 data ‘\0‘ 16 next 0x804b018 17 *0x804b018 18 data ‘a‘ 19 next 0x804b038 20 *0x804b038 21 data ‘s‘ 22 next ox804b048 23 *0x804b048 24 ... 25 注:最后一个节点的next为NULL 26 */ 27 28 //初始化单链表(创建单链表) 29 linkList* linkListCreate() 30 { 31 char ch; 32 //p为创建的单链表,p2链接于p上,p1是p2与p之间的桥梁 33 linkList *p,*p1,*p2; 34 //初始化表头 35 p=(linkList*)malloc(sizeof(linkList)); 36 p->data=http://www.mamicode.com/‘\0‘; 37 p->next=NULL; 38 p1=p;//将p的首地址给p1,对p1的操作就是对p中元素的操作 39 while((ch=getchar())!=‘\n‘) 40 { 41 p2=(linkList*)malloc(sizeof(linkList)); 42 p2->data=http://www.mamicode.com/ch; 43 p2->next=NULL; 44 p1->next=p2; 45 p1=p2; 46 } 47 return p;//返回链表头指针 48 } 49 50 //查找节点:按序号查找,查找链表list中第n个节点。注:链表头的下一个节点才是第一个节点 51 linkList * ElemLocatebyNum(linkList *list,int n) 52 { 53 int i=0; 54 linkList *p; 55 p=list; 56 while(p!=NULL) 57 { 58 i++; 59 p=p->next; 60 if(n==i) 61 { 62 return p; 63 } 64 } 65 return NULL; 66 } 67 68 //查找节点:按数据元素查找,查找链表list中元素为ch的节点 69 linkList * ElemLocatebyVal(linkList *list,char ch) 70 { 71 linkList *p; 72 p=list; 73 while(p!=NULL) 74 { 75 p=p->next; 76 if(ch==p->data) 77 { 78 return p; 79 } 80 } 81 return NULL; 82 } 83 84 //插入节点:在链表list的第n个节点处插入元素ch 85 void linkListInsert(linkList *list,int n,char ch) 86 { 87 linkList *p,*q; 88 p=ElemLocatebyNum(list,n-1);//链表第n-1个节点 89 if(p==NULL) 90 { 91 printf("insert error!\n"); 92 return; 93 } 94 q=(linkList*)malloc(sizeof(linkList)); 95 q->data=http://www.mamicode.com/ch; 96 q->next=p->next; 97 p->next=q; 98 } 99 100 //删除节点:删除链表list的第n个节点101 void linkListDelete(linkList *list,int n)102 {103 linkList *p,*q;104 p=ElemLocatebyNum(list,n-1);//链表第n-1个节点105 //q=ElemLocatebyNum(list,n);//链表的第n个节点106 if(p->next==NULL || p==NULL)107 {108 printf("delete error!\n");109 return;110 }111 q=p->next;112 p->next=q->next;113 free(q);//释放第n个节点的内存空间114 }115 116 int main()117 {118 //创建链表119 linkList *p,*q;120 p=linkListCreate();121 q=p->next;//单链表的第一个节点122 printf("craete list/elment:\n");123 while(q)124 {125 printf("%c",q->data);126 q=q->next;127 }128 printf("\n");129 //查找节点:按序号130 q=ElemLocatebyNum(p,4);131 printf("find node/positon 4 elment:%c\n",q->data);132 //查找节点:按数据元素133 q=ElemLocatebyVal(p,‘j‘);134 printf("find node/element is:%c\n",q->data);135 //插入节点136 linkListInsert(p,4,‘Q‘);137 q=p->next;138 printf("insert node/elment:\n");139 while(q)140 {141 printf("%c",q->data);142 q=q->next;143 }144 printf("\n");145 //删除节点146 linkListDelete(p,7);147 q=p->next;148 printf("delete node/elment:\n");149 while(q)150 {151 printf("%c",q->data);152 q=q->next;153 }154 printf("\n");155 return 0;156 }
1.链表初始化:这里有一个链表头,用于指向链表的头节点,即链表头的下一个节点即为链表的第一个节点。
2.查找节点,有两种查找方式,按序号查找和按数据元素查找。
3.插入节点,一定要注意操作的先后顺序。
4.删除节点,最后一定要将删除节点的内存空间释放掉,避免造成内存泄漏。
[转载(有删改)]单链表
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。