欢迎来到天天文库
浏览记录
ID:34010948
大小:76.50 KB
页数:6页
时间:2019-03-03
《单链表的创建及操作》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、山东师范大学实验报告课程:数据结构班级:2013级1班实验序号:116王海峰姓名:王海峰学号:201311010116实验日期:2014.3.25题目:单链表的创建及操作一、实验目的和要求(1)熟悉C语言的上机环境,进一步掌握C语言的结构特点。(2)掌握线性表的顺序存储结构的定义及基本运算二、实验环境Windows8,vc++6.0三、实验内容及实施实验内容1、创建一个带头结点的单链表(头指针为head),且遍历此链表(输出链表中各结点的值);2、查找单链表中的第i个结点,并输出结点元素的值;3、在单链表中的第i个结点前插入一个结点值为
2、e的正整数(从外部输入);4、删除单链表中的第j个结点;*5、将单链表中的各结点就地逆序(不允许另建一个链表);【程序】#include#include#include//数据结构作业201311010116计一王海峰structLinked{intdate;//定义结点的数据域structLinked*next;//定义结点的指针域};voidInitList(structLinked*head);//建立单链表voidputout(structLinked*head);//
3、输出单链表voiddel(structLinked*head);//删除元素voidchange(structLinked*head);//就地逆序voidfree(structLinked*head);//释放内存voidsearch(structLinked*head);//查找元素voidInsert(structLinked*head);//插入元素intmain(){Linked*head;head=(Linked*)malloc(sizeof(Linked));//为头指针分配空间if(head==NULL)exit(1);
4、//建立单链表InitList(head);//查找第i个结点search(head);//插入结点Insert(head);printf("插入后的链表为:");putout(head);//删除第j个结点del(head);printf("删除后的链表为:");putout(head);//单链表就地逆序change(head);printf("逆序后的单链表为:");putout(head);//释放内存free(head);printf("");return0;}//建立单链表voidInitList(structL
5、inked*head){Linked*p,*q;p=(Linked*)malloc(sizeof(Linked));if(p==NULL)exit(1);q=(Linked*)malloc(sizeof(Linked));if(q==NULL)exit(1);head->next=NULL;//将头指针置空charch;//判断数据是否输入结束q=head;printf("请输入一组数据");//动态创建链表while((ch=getchar())!='')//判断数据是否输入结束{ungetc(ch,stdin);p=(Lin
6、ked*)malloc(sizeof(Linked));if(p==NULL)exit(1);scanf("%d",&p->date);//输入数据p->next=NULL;//后继置空q->next=p;//连接前驱结点q=p;}}//查找voidsearch(structLinked*head){Linked*p,*q;p=(Linked*)malloc(sizeof(Linked));//为工作指针分配空间if(p==NULL)exit(1);inti,k;printf("输入要查找的结点序数:");scanf("%d",&i);
7、p=head->next;for(k=1;knext;printf("%d",p->date);//此时p为i的后继结点}//单链表就地逆序voidchange(structLinked*head){structLinked*t;//临时指针Linked*p,*q;t=p=q=head->next;while(t->next->next)t=t->next;while(q->next)q=q->next;while(q->next!=p&&p!=q){head->date=p->date;//p与q交换数据域
8、p->date=q->date;q->date=head->date;q=t;t=head->next;while(t->next!=q)t=t->next;p=p->next;}}//释放内存空间void
此文档下载收益归作者所有