《中南民族大学《数据结构》学生实验报告》由会员分享,可在线阅读,更多相关《中南民族大学《数据结构》学生实验报告(23页珍藏版)》请在金锄头文库上搜索。
1、院 系: 计算机科学学院 专 业: 网络工程 年 级: 2012 课程名称: 数据结构 学 号: 姓 名: 指导教师: 2014年6月日年级2012班号1201组号学号专业网络工程姓名实验名称第二章 线性表实验室实验目的或要求 了解线性表的逻辑结构和各种存储表示方法,以及定义在逻辑结构上的各种基本运算及其在某种存储结构上如何实现这些基本运算。在熟悉上述内容的基础上,能够针对具体应用问题的要求和性质,选择合适的存储结构设计出相应的有效算法,解决与线性表相关的实际问题。实验原理(算法流程)1、 实验内容单链表的各种基本操作,包括创建,查找,插入,删除,输出,合并等2、存储结构描述及说明链式存储结构
2、typedef struct node char data; struct node *next; linklist;3、函数说明linklist *rcrect(linklist *head) 尾插法建立单链表void print(linklist *head) 输出函数,输出单链表。linklist location(linklist *head) 按序号查找函数,按序号查找单链表中数据。linklist inset(linklist *head) 插入函数,在单链表中插入数据。linklist delet(linklist *head) 删除函数,删除单链表中的数据。int main()
3、 主函数,程序运行调用各子函数。4、模块之间的调用关系开 始主函数创建单链表查找单链表数据删除数据输出函数插入函数程序清单:#include#include#include typedef struct node /定义节点类型 char data; struct node *next; /因为上面结构体的类型名是struct node linklist是别名 linklist; /一般List顺序表,linklist链表int main() int a; linklist *head; head=(linklist *)malloc(sizeof(linklist); printf(请先建立
4、单链表!n); linklist *rcrect(linklist *head); /调用尾插法 rcrect(head); /*linklist *hcrect(); /或者调用头插法 hcrect();*/ for(;) printf(n您想要对此单链表表做何种操作:n0.退出t1.查找t2.插入t3.删除n); scanf(%d,&a); if(a3) printf(您输入的数字有误,请重新输入!n); if(a=0) /退出 exit(0); if(a=1) linklist location(linklist *head); /调用按序号查找函数 location(head); if
5、(a=2) linklist inset(linklist *head); /调用插入函数 inset(head); if(a=3)/调用删除函数 linklist delet(linklist *head); /调用删除函数 delet(head); return 0;/1.尾插法建立单链表linklist *rcrect(linklist *head) /尾插法 链接到已经建立好的单链表的末尾 linklist *p,*last; char ch; /用于输入字符 last=head; printf(请输入你要存储的字符,以!号结束:n); while(ch!=!) p=(linklist
6、 *)malloc(sizeof(linklist); scanf(%c,&ch); p-data=ch; /每次都申请一个节点,数据域存放数据,指针域为空 / printf(%ct,p-data); 可以用来测试存储是否正确 last-next=p; last=p; /上一次的最后一个元素的地址赋给last p-next=NULL; void print(linklist *head); /调用输出函数 print(head); return head;/2.输出函数函数void print(linklist *head) linklist *p; p=head-next; printf(n
7、你存储的数据为:n); while(p!=NULL) printf(%ct,p-data); p=p-next; /3.按序号查找函数linklist location(linklist *head) linklist *p; int i,k=0; p=head; printf(n请输入你要查找链表中第几个元素:n); scanf(%d,&i); while(p&knext; k+; if(ki|!p) printf(输入的序号有误,查找失败!n); exit(0); else printf(第%d个元素的值为:%cn,i,p-data); return *head;/4.插入函数linkli
8、st inset(linklist *head) linklist *p,*p1; int i,k=0; char ch; p=head; /不能为head-next printf(请输入你要在链表的第几个位置?t插入什么元素?n); scanf(%d %c,&i,&ch); p1=(linklist *)malloc(sizeof(linklist); /新建一个节点 p1-data=ch; p1-next=NULL; while(p&knext; k+; if(ki-1|!p) printf(输入的序号有误,插入失败!n); exit(0); else p1-next=p-next; p-next=p1; printf(插入后的新数据为:n); /输出插入后的新数据 p=head-next;