单链表基本操作实验.docx

单链表基本操作实验.docx

ID:59343156

大小:12.74 KB

页数:8页

时间:2020-10-31

单链表基本操作实验.docx_第1页
单链表基本操作实验.docx_第2页
单链表基本操作实验.docx_第3页
单链表基本操作实验.docx_第4页
单链表基本操作实验.docx_第5页
资源描述:

《单链表基本操作实验.docx》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、实验2链表的操作实验内容:1)基础题:编写链表基本操作函数,链表带有头结点(1)CreatList_h()//用头插法建立链表(2)CreateList_t()//用尾插法建立链表(3)InsertList()向链表的指定位置插入元素(4)DeleteList()删除链表中指定元素值(5)FindList()查找链表中的元素(6)OutputList()输出链表中元素2)提高题:(1)将一个头节点指针为heada的单链表A分解成两个单链表A和B,其头结点指针分别为heada和headb,使得A表中含有原单链表A中序号为

2、奇数的元素,B表中含有原链表A中序号为偶数的元素,且保持原来的相对顺序。(2)将一个单链表就地逆置。即原表(a1,a2,。。。。。。an),逆置后新表(an,an-1,。。。。。。。a1)/*程序功能:单链表基本功能操作编程者:杨天啸日期:2016-04-14版本号:3.0*/#include#includetypedefstructList{intdata;structList*next;}List;voidCreatList_h(List*L)//头插法{inti=0;intn

3、=0;intgoal;List*p;printf("请输入数据的个数:");scanf("%d",&n);L->next=NULL;for(i=0;idata=goal;p->next=L->next;//将L指向的地址赋值给p;L->next=p;}}voidCreateList_t(List*L)//尾插法{inti;i

4、ntn;intgoal;List*p;List*q=L;printf("请输入数据的个数:");scanf("%d",&n);for(i=0;idata=goal;q->next=p;q=p;}q->next=NULL;}voidInsList(List*L,inti,inte)//插入{List*s;List*p=L;in

5、tj=0;while(p&&jnext;++j;}s=(structList*)malloc(sizeof(structList));s->data=e;//插入L中s->next=p->next;p->next=s;return;}voidDeleteList(List*L,inte)//删除{List*q;List*p=L;while(p->next&&p->next->data!=e){p=p->next;}if(!(p->next)){printf("不存在该元素!");exit(0)

6、;}q=p->next;p->next=q->next;e=q->data;free(q);return;}voidFindList(List*L,inte)//查找元素{intj=1;List*p=L->next;while(p&&p->data!=e){p=p->next;++j;}if(!p){printf("不存在该元素!");exit(0);}printf("您查找的元素位置为:%d",j);return;}voidDisPlay(List*L)//输出链表{List*p=L->next;printf

7、("您输入的数据为:");while(p!=NULL){printf("%d",p->data);p=p->next;}printf("");}voidInverse(List*L)//单链表就地逆置{List*q;List*p=L->next;L->next=NULL;while(p!=NULL){q=p->next;//q指针保留原链表当前处理节点的下一个节点p->next=L->next;//将当前处理节点p插入到逆置L的表头L->next=p;p=q;//p指向下一个待插入的节点}}voidDisCre

8、at(List*L)//链表拆分{inti=0;//i记录表A中结点的序号List*p;List*B=(structList*)malloc(sizeof(structList));//创建B表表头B->next=NULL;//B表初始化List*ra=L,*rb=B;//ra和rb将分别指向将创建的A表和B表的尾结点p=L->n

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。