運行環境:Dev-C++
vs2013可能不能運行
首先新建一個頭文件slnklist.h
#include <stdio.h> #include <stdlib.h> /**************************************/ /* 鏈表實現的頭文件,文件名slnklist.h */ /**************************************/ typedef int datatype; typedef struct link_node{ datatype info; struct link_node *next; }node; typedef node *linklist; /**********************************/ /*函數名稱:creatbystack() */ /*函數功能:頭插法建立單鏈表 */ /**********************************/ linklist creatbystack() { linklist head,s; datatype x; head=NULL; printf("請輸入若干整數序列:\n"); scanf("%d",&x); while (x!=0) /*以0結束輸入*/ { s=(linklist)malloc(sizeof(node)); /*生成待插入結點*/ s->info=x; s->next=head; /*將新結點插入到鏈表最前面*/ head=s; scanf("%d",&x); } return head; /*返回建立的單鏈表*/ } /**********************************/ /*函數名稱:creatbyqueue() */ /*函數功能:尾插法建立單鏈表 */ /**********************************/ linklist creatbyqueue() { linklist head,r,s; datatype x; head=r=NULL; printf("請輸入若干整數序列:\n"); scanf("%d",&x); while (x!=0) /*以0結束輸入*/ { s=(linklist)malloc(sizeof(node)); s->info=x; if (head==NULL) /*將新結點插入到鏈表最后面*/ head=s; else r->next=s; r=s; scanf("%d",&x); } if (r) r->next=NULL; return head; /*返回建立的單鏈表*/ } /**********************************/ /*函數名稱:print() */ /*函數功能:輸出不帶頭結點的單鏈表 */ /**********************************/ void print(linklist head) { linklist p; int i=0; p=head; printf("List is:\n"); while(p) { printf("%5d",p->info); p=p->next; i++; if (i%10==0) printf("\n"); } printf("\n"); } /**********************************/ /*函數名稱:delList() */ /*函數功能:釋放不帶頭結點的單鏈表 */ /**********************************/ void delList(linklist head) { linklist p=head; while (p) { head=p->next; free(p); p=head; } }
1.編寫函數slnklist delx(linklist head, datatype x),刪除不帶頭結點單鏈表head中第一個值為x 的結點。 並構造測試用例進行測試。
/*編寫函數slnklist delx(linklist head, datatype x),刪除不帶頭結點單鏈表head中第一個值為x 的結點。 並構造測試用例進行測試。 */ /**********************************/ /*文件名稱:lab2_01.c */ /**********************************/ #include "slnklist.h" /*請將本函數補充完整,並進行測試*/ linklist delx(linklist head,datatype x) { linklist p = head,pre=NULL;//一定要初始化pre=NULL while(p&&p->info!=x) { pre = p; p = p->next; } if(p) { if(!pre) { head = head->next; } else { pre->next = p->next; free(p); } } return head; } int main() { datatype x; linklist head; head=creatbyqueue(); /*尾插入法建立單鏈表*/ print(head); printf("請輸入要刪除的值:"); scanf("%d",&x); head=delx(head,x); /*刪除單鏈表的第一個值為x的結點*/ print(head); delList(head); /*釋放單鏈表空間*/ return 0; }
2.假設線性表(a1,a2,a3,…an)采用不帶頭結點的單鏈表存儲, 請設計算法函數linklist reverse1(linklist head)和 void reverse2(linklist *head)將不帶頭結點的單鏈表head就地倒置, 使表變成(an,an-1,…a3.a2,a1)。並構造測試用例進行測試。
/**********************************/ /*文件名稱:lab2_02.c */ /**********************************/ /* 假設線性表(a1,a2,a3,…an)采用不帶頭結點的單鏈表存儲, 請設計算法函數linklist reverse1(linklist head)和 void reverse2(linklist *head)將不帶頭結點的單鏈表head就地倒置, 使表變成(an,an-1,…a3.a2,a1)。並構造測試用例進行測試。 */ #include "slnklist.h" /*請將本函數補充完整,並進行測試*/ linklist reverse1(linklist head) { linklist p,q; p=head; head = NULL; while(p) //核心 { q = p->next; p->next = head; head=p; p=q; } return head; } void reverse2(linklist *head) //不返回值,那就從指針上下手 { linklist p,q; p=*head; *head = NULL; while(p) { q = p->next; p->next = *head; *head=p; p=q; } } int main() { datatype x; linklist head; head=creatbystack(); /*頭插入法建立單鏈表*/ print(head); /*輸出原鏈表*/ head= reverse1(head); /*倒置單鏈表*/ print(head); /*輸出倒置后的鏈表*/ reverse2(&head); /*倒置單鏈表*/ print(head); delList(head); return 0; }
3.假設不帶頭結點的單鏈表head是升序排列的,設計算法函數linklist insert(linklist head,datatype x), 將值為x的結點插入到鏈表head中,並保持鏈表有序性。 分別構造插入到表頭、表中和表尾三種情況的測試用例進行測試。
/* 假設不帶頭結點的單鏈表head是升序排列的,設計算法函數linklist insert(linklist head,datatype x), 將值為x的結點插入到鏈表head中,並保持鏈表有序性。 分別構造插入到表頭、表中和表尾三種情況的測試用例進行測試。 */ /**********************************/ /*文件名稱:lab2_03.c */ /**********************************/ #include "slnklist.h" /*請將本函數補充完整,並進行測試*/ linklist insert(linklist head ,datatype x) { linklist pre,p,s; s = (linklist)malloc(sizeof(node)); s->info = x; p = head; pre=NULL; while(p&&p->infonext; } if(!pre) //插在表頭 { s->next = head; head = s; }else{ //插在中間或者末尾 pre->next = s; s->next = p; } return head; } int main() { datatype x; linklist head; printf("輸入一組升序排列的整數:\n"); head=creatbyqueue(); /*尾插入法建立單鏈表*/ print(head); printf("請輸入要插入的值:"); scanf("%d",&x); head=insert(head,x); /*將輸入的值插入到單鏈表適當位置*/ print(head); delList(head); return 0; }
4.編寫算法函數linklist delallx(linklist head, int x),刪除不帶頭結點單鏈表head中所有值為x的結點。
/* 編寫算法函數linklist delallx(linklist head, int x),刪除不帶頭結點單鏈表head中所有值為x的結點。 */ /**********************************/ /*文件名稱:lab2_04.c */ /**********************************/ #include "slnklist.h" /*請將本函數補充完整,並進行測試*/ linklist delallx(linklist head,int x) { linklist p,t; while(head)//如果要刪除的是第一個 { if(head->info==x) { p=head; head=head->next; free(p);//回收p } else { break; } } if(head)//如果刪除的不是第一個 { p=head; while(p->next) { if(p->next->info==x) { t=p->next; p->next=p->next->next; free(t); } else { p=p->next; } } } return head; } int main() { datatype x; linklist head; head=creatbyqueue(); /*尾插入法建立單鏈表*/ print(head); printf("請輸入要刪除的值:"); scanf("%d",&x); head=delallx(head,x); print(head); delList(head); return 0; }