欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    2022年2022年链表的合并-实验报告 .pdf

    • 资源ID:39735077       资源大小:613.45KB        全文页数:14页
    • 资源格式: PDF        下载积分:4.3金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要4.3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    2022年2022年链表的合并-实验报告 .pdf

    .1/14 课程设计报告课程设计题目:两个链表的合并专业:软件工程班级:姓名:学号:指导教师:年月日名师资料总结-精品资料欢迎下载-名师精心整理-第 1 页,共 14 页 -.2/14 目录1.课程设计的目的与要求2.课程设计的容分析和设计3.算法流程图4.详细步骤5.代码6.显示结果7.课程设计的总结名师资料总结-精品资料欢迎下载-名师精心整理-第 2 页,共 14 页 -.3/14 一课程设计的目的与要求1.目的:实现两个链表的合并2.要求:1 建立两个链表A 和 B,链表元素个数分别为m 和 n 个。2 假设元素分别为(x1,x2,xm),和(y1,y2,yn)。把它们合并成一个线形表C,使得:当 m=n 时,C=x1,y1,x2,y2,xn,yn,xm 当 nm 时,C=y1,x1,y2,x2,ym,xm,yn 输出线形表C 3 用直接插入排序法对C 进展升序排序,生成链表D,并输出链表D。4 能删除指定单链表中指定位子和指定值的元素。二课程设计的容分析和设计1.分析由题目的相关信息可以分析得:首先我们需要建立两个链表AB,A 链表的元素个数为m,B 链表的元素个数为n;在将 A、B 链表进展合并,根据 m 和 n 的大小关系决定链表C 的元素顺序;再将C 进展直接插入排序得到一个新的链表D;没次输入完一次链表信息,程序都会对相应的链表进展输入操作以此确保程序输入的数据是你想要输入的数据。同时当你合并好和排序好后都会进展输出操作。最后当排序好后你可以指定你所要删除数据的位置来删除你所要删除的数据。2.设计本次课程设计所需要用到的是关于链表的建立、合并以与直接插入排序的排序算法。需要先建立两个链表,再将其合并为一个无序链表,最后对这个无序链表进展直接插入排序并将其输出。难点在于将AB 合并为链表C 的操作以与对链表C 进展直接插入排序的操作和根据用户的意愿可以对链表进展删除的操作。三算法流程图名师资料总结-精品资料欢迎下载-名师精心整理-第 3 页,共 14 页 -.4/14 四详细步骤(1)结构体的创建:struct Node(2)链表的创建:struct Node*create链表的创建。(3)链表的输出:void print(struct Node*head)功能是对链表进展输出。(4)链表的合并:struct Node*inter_link(struct Node*chain1,int a,struct Node*chain2,int b)算法的功能是实现两个链表的交叉合并,并且可以根据两链表的长短将行不通的插入。(5)排序:void InsertSort(struct Node*p,int m)算法的功能是对一合并好的链表进展升序插入排序。(6)按位删除操作:struct Node*delete_link(struct Node*p,int i)。(7)按值删除操作:struct Node*delete_linkz(struct Node*p,int i)。(8)主函数:main()函数主要是对算法进展测试。建立链表 A 建立链表B 合并 A B 链表得到 C 链表得到 D 链表得到 E 链表比拟 m.n 排序删除名师资料总结-精品资料欢迎下载-名师精心整理-第 4 页,共 14 页 -.5/14 五代码struct Node/数据结构定义如下:long int number;struct Node*next;Node,*linkList;#include/源程序:#include#include#include#define error 0#define null 1#define L sizeof(struct Node)struct Node*create(int a)/链表创建函数 int n;struct Node*p1,*p2,*head;head=NULL;n=0;p2=p1=(struct Node*)malloc(L);/分配存scanf(%ld,&p1-number);while(a)/录入链表信息 n=n+1;if(n=1)head=p1;else p2-next=p1;p2=p1;p1=(struct Node*)malloc(L);if(a!=1)/分配存scanf(%ld,&p1-number);a-;/控制输入的个数 p2-next=NULL;return(head);/链表创建函数完毕void print(struct Node*head)/输出函数名师资料总结-精品资料欢迎下载-名师精心整理-第 5 页,共 14 页 -.6/14 struct Node*p;p=head;printf(数字:n);if(head!=NULL)do/循环实现输出 printf(%ld,p-number);printf();p=p-next;while(p!=NULL);printf(n);/链表的交叉合并算法struct Node*inter_link(struct Node*chain1,int a,struct Node*chain2,int b)int temp;struct Node*head,*p1,*p2,*pos;/*判断 a,b 大小并合并*/if(a=b)head=p1=chain1;p2=chain2;else/*ba*/head=p1=chain2;p2=chain1;temp=a,a=b,b=temp;/*交换 a 和 b*/*下面把 p1 的每个元素插在 p2 相应元素之前,p1 长 a,p2长 b*/pos=head;/*此时 pos指向 p1 中的第一个元素*/while(p2!=NULL)/漂亮,蛇形插入p1=p1-next;pos-next=p2;pos=p2;p2=p2-next;pos-next=p1;pos=p1;return head;/对合并好的链表进展排序void InsertSort(struct Node*p,int m)/排序函数 名师资料总结-精品资料欢迎下载-名师精心整理-第 6 页,共 14 页 -.7/14 int i,j,t;struct Node*k;k=p;for(i=0;i m-1;i+)for(j=0;j number (p-next)-number)t=p-number;p-number=(p-next)-number;(p-next)-number=t;p=p-next;p=k;struct Node*delete_link(struct Node*p,int i)/按位删除 struct Node*q;int j=0;while(jnext)p=p-next;j+;if(j=i-1&p-next)q=p-next;p-next=q-next;free(q);else return error;struct Node*delete_linkz(struct Node*p,int i)/按值删除 struct Node*q;struct Node*k;int j=0;int h=0;while(p&p-number!=i)p=p-next;j+;if(p)while(hnext)p=p-next;h+;名师资料总结-精品资料欢迎下载-名师精心整理-第 7 页,共 14 页 -.8/14 if(h=j-1&p-next)k=p-next;p-next=k-next;free(k);else return error;/主函数int main()/main 函数 struct Node*p1,*p2;int a;int b;int h;int t;int m;printf(请输入第一个链表:n);printf(n 输入链表的长度a:n);scanf(%d,&a);printf(请输入链表数据:);p1=create(a);printf(n 你刚刚输入的第一个链表信息:n);print(p1);printf(n 请输入第二个链表:n);printf(n 输入链表的长度b:n);scanf(%d,&b);printf(请输入链表数据:);p2=create(b);printf(n 你刚刚输入的第二个链表的信息:n);print(p2);p1=inter_link(p1,a,p2,b);h=a+b;printf(n 合并后的链表 n:);print(p1);InsertSort(p1,h);printf(n 排序后的链表:n);print(p1);printf(n 请输入链表中你所要删除数据的所在位置:n);scanf(%d,&t);delete_link(p1,t);printf(n 链表删除数据后链表的信息:n);名师资料总结-精品资料欢迎下载-名师精心整理-第 8 页,共 14 页 -.9/14 print(p1);printf(n 请输入你想要删除的数值:n);scanf(%d,&m);delete_linkz(p1,m);printf(n 链表删除数据后链表的信息:n);print(p1);return 0;六显示结果1mn 名师资料总结-精品资料欢迎下载-名师精心整理-第 10 页,共 14 页 -.11/14 3.m=n 名师资料总结-精品资料欢迎下载-名师精心整理-第 11 页,共 14 页 -.12/14 4.按位删除操作名师资料总结-精品资料欢迎下载-名师精心整理-第 12 页,共 14 页 -.13/14 5.按值删除名师资料总结-精品资料欢迎下载-名师精心整理-第 13 页,共 14 页 -.14/14 七课程设计的总结通过进一周的学习和实践,解决实际问题,让我对链表有了更深的了解,也让我提高了解决实际问题的能力。在上机的同时改正了自己对某些算法的错误使用,使自己在通过程序解决问题时抓住关键算法,有了算法设计思想和流程图,并用C 语言描绘出关键算法。在运行过程中,用户可输入你所需合并的两个链表,首先输入你所要输入链表的长度再输入链表的数据,完成第一个链表的输入后,按照同样的方法输入第二个链表,每输入完一个链表程序都会执行输出函数void print(struct Node*head)对链表进展输出,以此让用户可以确认自己输入的数据是否准确。当用户输入完第二个链表时,程序会先执行struct Node*inter_link(struct Node*chain1,int a,struct Node*chain2,int b)再执行 void InsertSort(struct Node*p,int m)来进展合并和排序。合并之后和排序后又分别会再次执行输出函数,以此输出合并后和排序后的链表数据。之后相应的按照用户的需要可以删除所要删除的数据。名师资料总结-精品资料欢迎下载-名师精心整理-第 14 页,共 14 页 -

    注意事项

    本文(2022年2022年链表的合并-实验报告 .pdf)为本站会员(C****o)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开