后天就要程序设计考试了,今晚抓紧复习链表ing!
这次就来总结一下链表的六大基础操作:
(1)创建链表
(2)遍历链表
(3)在链表中检索
(4)向链表中插入一项
(5)从链表中删除一项
(6)交换链表中两项的位置
全部都放在一个代码里了,这样好操作一点 /笑哭
至于链表的引申操作,什么头插法尾插法的,都是这六大基础操作之外的事情,有兴趣的话烦请各位自己去了解啦,我这里就不介绍了~
注释都非常详细,我是真的没有啥时间画图做解释了,将就着看吧~
(毕竟我个人也不喜欢一上来啥也不说就版代码的,那会让我很暴躁)
1 #include <stdio.h> 2 #include <string.h> 3 #include <stdlib.h> 4 const int SIZE = 5;//5个学生信息节点作为测试样例 5 typedef struct student 6 { 7 int number;//学号 8 char name[30];//姓名 9 int score;//成绩 10 struct student* next;//指向下一节点的指针 11 }student; 12 13 student* input(student* stu)//操作①:创建链表 14 { 15 int i; 16 student* p;//将要插入的新节点 17 student* q;//一个引子 18 printf("请输入学生的学号,姓名,成绩(以空格分隔): "); 19 q = stu;//q初始指向表头 20 for (i = 0; i < SIZE; i++) 21 { 22 p = (student*)malloc(sizeof(student));//为即将插入的信息节点申请空间 23 scanf("%d %s %d", &p->number, p->name, &p->score); 24 p->next = q->next;//保证q->next一定是NULL,排除指向空的情况 25 q->next = p; 26 q = q->next; 27 } 28 return stu; 29 } 30 31 void output(student* stu)//操作②:从头遍历链表(并输出) 32 { 33 student* p = stu->next; 34 while (p != NULL) 35 { 36 printf("%d %s %d ", p->number, p->name, p->score); 37 p = p->next; 38 } 39 } 40 41 student* check(student* stu)//操作③:在链表中检索某个节点,并带回主函数输出(在这里我以找到第一个成绩为66的学生信息,带回主函数输出为例) 42 { 43 student* p = stu->next; 44 while (p != NULL) 45 { 46 if (p->score == 66) 47 { 48 return p;//找到了返回指针p 49 } 50 else 51 { 52 p = p->next;//否则继续往下找 53 } 54 } 55 return p; 56 } 57 58 student* insert_s(student* stu, student* temp)//操作④:在链表中插入一个节点temp,并带回主函数输出 59 { 60 int flag = 1;//不能写成2,那样会找到第三节点,想想为什么? 61 student* p = stu->next; 62 while (flag)//找到第二节点,并用指针p指向 63 { 64 p = p->next; 65 flag--; 66 } 67 temp->next = p->next; 68 p->next = temp;//注意:此行和上一行不能调换,否则会导致节点丢失! 69 return stu; 70 } 71 72 student* del(student* stu)//操作⑤:删除链表中的某个节点,并带回主函数,输出 73 { 74 int flag = 1; 75 student* p = stu->next; 76 student* q;//q是要删除的那一个节点(在本题中指第三节点) 77 while (flag)//找到第二节点,并用指针p指向 78 { 79 p = p->next; 80 flag--; 81 } 82 q = p->next; 83 q = q->next; 84 free(p->next);//释放节点 85 p->next = q; 86 return stu; 87 } 88 89 student* exchange(student* stu) 90 { 91 int flag1 = 1;//第二节点 92 int flag2 = 4;//第五节点 93 int flag11 = flag1-1;//第二节点前驱节点 94 int flag22 = flag2-1;//第五节点前驱节点 95 student* p = stu->next;//前方节点(在本题中指第二节点) 96 student* q = stu->next;//后方节点(在本题中指第五节点) 97 student* pp = stu->next;//前方节点的前驱节点(在本题中指第一节点) 98 student* qq = stu->next;//后方节点的前驱节点(在本题中指第四节点) 99 student* temp;//中介变量 100 while (flag1)//定位节点p 101 { 102 p = p->next; 103 flag1--; 104 } 105 while (flag2)//定位节点q 106 { 107 q = q->next; 108 flag2--; 109 } 110 while (flag11)//定位节点pp 111 { 112 pp = pp->next; 113 flag11--; 114 } 115 while (flag22)//定位节点qq 116 { 117 qq = qq->next; 118 flag22--; 119 } 120 /*=================*///交换p->next和q->next 121 temp = p->next; 122 p->next = q->next; 123 q->next = temp; 124 /*=================*///交换pp->next和qq->next 125 pp->next = q; 126 qq->next = p; 127 /*=================*///交换p和q 128 p = pp->next; 129 q = qq->next; 130 /*=================*/ 131 return stu; 132 } 133 134 int main() 135 { 136 student* stu;//定义表头指针 137 student* s;//中介指针1 138 student* ss;//中介指针2 139 student* temp; 140 /*======================================================*///建立表头 141 stu = (student*)malloc(sizeof(student));//为表头节点分配空间 142 stu->next = NULL; 143 /*======================================================*/ 144 //操作①:建立单链表,并用s指向 145 s = input(stu); 146 147 //操作②:输出这个链表 148 printf(" "); 149 output(s); 150 151 //操作③:在链表中检索某个节点,并用s指向 152 ss = check(s); 153 printf(" %d %s %d ", ss->number, ss->name, ss->score);//输出特定节点的所有信息 154 155 //操作④:在建立好的链表第二三节点间插入节点temp,并输出检验 156 temp = (student*)malloc(sizeof(student)); 157 scanf("%d %s %d", &temp->number, temp->name, &temp->score); 158 ss = insert_s(s, temp); 159 printf(" "); 160 output(ss); 161 162 //操作⑤:删除已经建立好的链表中的第三节点,并输出检验 163 ss = del(s); 164 printf(" "); 165 output(ss); 166 167 //操作⑥:交换建立好的链表中的第二和第五节点,并输出检验 168 ss = exchange(s); 169 printf(" "); 170 output(ss); 171 return 0; 172 }