首页 > 编程语言 > 详细

c语言实现对传统单链表的创建、添加 遍历 删除 反转元素操作

时间:2016-02-27 23:28:27      阅读:322      评论:0      收藏:0      [点我收藏+]

1、链表定义

  链表是一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。链表由一系列结点(链表中每一个元素称为结点)组成,结点可以在运行时动态生成。每个结点包括两个部分:一个是存储数据元素的数据域,另一个是存储下一个结点地址的指针域。

typedef struct Node {
    int data;
    struct Node *next;    //next指针指向自己这种数据类型,这就形成了链表
}SList;

技术分享

                      单向链表的结构图

2、创建、添加 遍历 删除 反转元素操作功能实现

  1 #include <stdio.h>
  2 #include <stdlib.h>
  3 
  4 typedef struct Node {
  5     int data;
  6     struct Node *next;
  7 }SList;
  8 
  9 int SList_Create(SList **p/**out*/) {
 10     int data = 0;
 11     int ret = 0;
 12     SList *pHead = NULL;
 13     SList *node = NULL;
 14     SList *tmp = NULL;
 15     pHead = (SList *)malloc(sizeof(SList));
 16     if(pHead == NULL) {
 17         ret = -1;
 18         printf("SList_Create erro\n");
 19         goto End;
 20     }
 21     tmp = pHead;
 22     printf("请输入一个整数数据\n");
 23     scanf("%d", &data);
 24     while(data != -1) {
 25         node = (SList *)malloc(sizeof(SList));
 26         if(node == NULL) {
 27             ret = -1;
 28             printf("SList_Create erro\n");
 29             goto End;
 30         }
 31         node->data = data;
 32         tmp->next = node;
 33         tmp = node;
 34         printf("请输入一个整数数据\n");
 35         scanf("%d", &data);
 36     }
 37     node->next = NULL;
 38     *p = pHead;
 39 End:
 40     if(ret != 0) {
 41         if(pHead != NULL) {
 42             free(pHead);
 43             pHead = NULL;
 44         }
 45         if(node != NULL) {
 46             free(node);
 47             node = NULL;
 48         }
 49     }
 50     return ret;
 51 }
 52 
 53 void print_List(SList *pHead) {
 54     SList *pTmp;
 55     if(pHead == NULL || pHead->next == NULL) {
 56         printf("SList is NULL\n");
 57     }
 58     pTmp = pHead;
 59     while(pTmp->next) {
 60         printf("%d ", pTmp->next->data);
 61         pTmp = pTmp->next;
 62     }
 63 }
 64 
 65 int insert_List(SList *pHead/**in*/, int targetNum, int insertNum) {
 66     int ret = 0;
 67     SList *pPre = NULL;
 68     SList *pCur = NULL;
 69     SList *pNode = NULL;
 70     if(pHead == NULL || pHead->next == NULL) {
 71         ret = -1;
 72         printf("insert_List erro\n");
 73         return ret;
 74     }
 75     pCur = pHead->next;
 76     pPre = pHead;
 77     pNode = (SList *)malloc(sizeof(SList));
 78     if(pNode == NULL) {
 79         ret = -1;
 80         printf("insert_List erro\n");
 81         return ret;
 82     }
 83     pNode->data = insertNum;
 84     while(pCur) {
 85         if(pCur->data == targetNum) {
 86             break;
 87         }else {
 88             pPre = pCur;
 89             pCur = pCur->next;
 90         }
 91     }
 92     pNode->next = pCur;
 93     pPre->next = pNode;
 94     return ret;
 95 }
 96 
 97 int delete_List(SList *pHead, int deleteNum) {
 98     int ret = 0;
 99     SList *pPre = NULL;
100     SList *pCur = NULL;
101     if(pHead == NULL || pHead->next == NULL) {
102         ret = -1;
103         printf("delete_List erro\n");
104         return ret;
105     }
106     pPre = pHead;
107     pCur = pHead->next;
108     while(pCur) {
109         if(pCur->data == deleteNum) {
110             break;
111         }else {
112             pPre = pCur;
113             pCur = pCur->next;
114         }
115     }
116     if(pCur == NULL) {
117         ret = -2;
118         printf("not exist this num");
119         return ret;
120     }
121     pPre->next = pCur->next;
122     pCur->next = NULL;
123     if(pCur != NULL) {
124         free(pCur);
125     }
126     return ret;
127 }
128 
129 void destory_List(SList **p) {
130     SList *pHead = NULL;
131     SList *tmp = NULL;
132     if(p == NULL || *p == NULL) {
133         return;
134     }
135     pHead = *p;
136     while(pHead) {
137         tmp = pHead->next;
138         if(pHead != NULL) {
139             free(pHead);
140         }
141         pHead = tmp;
142     }
143     *p = NULL;
144 }
145 
146 void reverse_List(SList *pHead) {
147     SList *pPre = NULL;
148     SList *pCur = NULL;
149     SList *pTmp = NULL;
150     if(pHead == NULL || pHead->next == NULL || pHead->next->next == NULL) {
151         return;
152     }
153     pPre = pHead->next;
154     pCur = pHead->next->next;
155     while(pCur) {
156         pTmp = pCur->next;
157         pCur->next = pPre;
158         pPre = pCur;
159         pCur = pTmp;
160     }
161     pHead->next->next = NULL;
162     pHead->next = pPre;
163 }
164 
165 int main() {
166     int ret = 0;
167     SList *node1 = NULL;
168     ret = SList_Create(&node1);
169     if(ret) {
170         printf("create list erro\n");
171     }
172     print_List(node1);
173     printf("\n insert_List\n");
174     insert_List(node1, 20, 19);
175     print_List(node1);
176     printf("\n delete_List\n");
177     delete_List(node1, 19);
178     print_List(node1);
179     printf("\n reverse_List\n");
180     reverse_List(node1);
181     print_List(node1);
182     printf("\n destory_List\n");
183     destory_List(&node1);
184     system("pause");
185     return 0;
186 }

 

c语言实现对传统单链表的创建、添加 遍历 删除 反转元素操作

原文:http://www.cnblogs.com/dengmj/p/5223670.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!