【2017年整理】数据结构实验一.docVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
【2017年整理】数据结构实验一

数据结构与算法 实验报告 实验题目: 大整数加法 班 级: 信息与计算科学141 姓 名: xx 学 号: 141021xx 完成日期: 2014.11.03 一、需求分析 1、实验任务是利用线性表的链式存储及其相应操作对两个非负整数(位数可能超过整数类型数据存储的范围)进行相加,求出结果。 2、输入的形式和输入值的范围: 输入的形式为字符,输入值的范围为整数。 3、输出的形式:整型 。 4、程序功能:实现任意位数的两个整数相加。 5、测试数据: 第一组 666666666666666666666666 222 第二组 12345678987654321 9876543212345678987654321 第三组 1333333333333333333333333333333333333333 2555555555555555555555555555555555555555 二、概要设计 1、数据类型 储存整数的单链表中的结点结构可以是: typedef struct line { int data; struct line *next; }list,*linklist; 2、算法思想 (1)输入两个正确的整数,由于输入整数位数可能超过整数数据类型可以存储的范围,所以要用字符数组的数据类型来接受输入的两个整数。考虑到每个长整型数的长度在输入之间是无法预知的,因此使用链表在存储空间的分配上更方便一些。 (2)对于存储在字符数组里的整数,可以根据字符数组中从高位到低位的数值位,用前插法建立单链表的方法,将整数存储于带头结点的单链表中每个结点存放一位数字,这时,从单链表的第一个结点到尾结点依次是从个位到最高位的整数,以便相加运算。 (3)对两个单链表依次扫描到尾结点,将尾结点的数值及前面相加留下的进位相加,把和的个位存储到长度长的单链表对应的结点中,同时记录进位, 3、各子模块 (1)输入整数,存入链表模块 该模块根据字符数组从高位到低位的数值位,用前插法建立单链表。 (2)链表输出模块 输出链表使得从第一个结点到尾结点依次是从个位到最高位的整数,这样便可以进行相加。 (3)整数相加模块 对两个单链表依次扫描到尾结点,将尾结点的数值及前面相加留下的进位相加,把和的个位存储到长度长的单链表对应的结点中,同时记录进位, 三、详细设计 1、数据结构 typedef struct line { int data; struct line *next; }list,*linklist; 2、输入整数,存入链表 void initList(linklist l)//输入整数,存入链表 { char c; linklist p; l=(linklist)malloc(sizeof(list)); l-next=0; while((c=getchar())!=\n) { p=(linklist)malloc(sizeof(list)); p-data=c-48; p-next=l-next; l-next=p; } } 3、输出单链表中的元素值 void print(linklist l)//输出链表 { l=l-next; while(l!=0) { printf(%d,l-data); l=l-next; } } 4、整数相加 void add(linklist l,linklist l1,linklist l2)//求和 { int a,b=0; linklist p; l1=l1-next; l2=l2-next; l=(linklist)malloc(sizeof(list)); l-next=0; while(l1!=0l2!=0) { a=l1-data+l2-data+b; l1=l1-next; l2=l2-next; b=a/10; a=a%10; p=(linklist)malloc(sizeof(list)); p-data=a; p-next=l-next; l-next=p; } if(!l1!l2) { if(b==1) { p=(linklist)malloc(sizeof(list)); p-data=1; p-next=l-next; l-next=p; } } if(l1) { while(l1!=0) { a=l1-data+b; l1=l1

文档评论(0)

liwenhua11 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档