欢迎来到天天文库
浏览记录
ID:9098983
大小:325.00 KB
页数:29页
时间:2018-04-17
《长整数加减运算实验报告》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、长整数加减的运算一、需求分析问题描述:设计一个实现任意长的整数进行加法运算的演示程序基本要求:利用双向循环链表实现长整数的存储,每个结点含一个整型变量。任何整型变量的范围是-(215-1)~(215-1)。输入输出形式:按照中国对于长整数的表示习惯,每四位是一组,组间用逗号隔开更高要求:(1)长整数的减法(2)多个长整数的连续加减法,并带括号等。具体方式可以参见表达式的求值部分,利用栈测试数据:(1)0;0;应输出“0”(2)-2345,6789;-7654,3211;应输出“-1,0000,0000”(3)-9999,99
2、99;1,0000,0000,0000;应输出“9999,0000,0001”(4)1,0001,0001;-1,0001,0001;应输出“0”(5)1,0001,0001;-1,0001,0000;应输出“1”(6)-9999,9999,9999;-9999,9999,9999;应输出“-1,9999,9999,9998”(7)1,0000,9999,9999;1;应输出“1,0001,0000,0000”一、概要设计1.数据结构此实验采用的数据结构是双向循环链表。这样可以很容易的找到他的前驱以及它的后继。节点采用结构体
3、类型,代码如下:typedefstructNode//双向链表的结构体定义{intdata;structNode*prior;structNode*next;}DLNode;2.使用函数1)voidListInitiate(DLNode**head)操作结果:初始化一个头结点为head的双向循环链表;2)intListLength(DLNode*head)操作结果:计算以head为头结点的链表的长度3)intListInsert(DLNode*head,inti,intx)操作结果:将节点数据为x的节点插到第i个位置上去。4
4、)intabs(intx)操作结果:绝对值函数,返回x的绝对值。5)intInputNumber(DLNode*head)操作结果:将从键盘中接收数据并把得到的数据存入以head为头结点的链表中。四位一存,中间以逗号区分,结束符为分号。6)voidOutputNumber(DLNode*head,intsign)操作结果:将以head为头结点的链表中的所有数据输出到显示屏上,7)voidadd(DLNode*head1,DLNode*head2,DLNode*head3)操作结果:实现正数加正数的加法操作。8)intchan
5、ge(DLNode*head1,DLNode*head2)操作结果:判断存在俩个链表中的数的大小,如何head1中的数大于head2中的数那么返回值为0,反之返回值为1,相等时返回值为2;1)voidmethod(DLNode*head1,DLNode*head2,intx)操作结果:计算正数乘以正数的乘法运算。2)voidminus(DLNode*head1,DLNode*head2,DLNode*head3)操作结果:计算正数减正数的减法运算。3)voidyunsuan(DLNode*head1,DLNode*head2
6、,DLNode*head3,charch)操作结果:正数,负数,加法,减法。计算式共分为八种运算,在这之前我已经实现了二种运算,那么这个函数就是把这八种运算按照一定的规则转化成已经实现的二种运算来实现完整的加减法运算。4)voidchengfa(DLNode*head1,DLNode*head2)操作结果:在乘法中我只是实现了正数乘以正数的运算,那么这个函数就是通过调用method函数按照一定的规则来实现完整的乘法运算。5)voidmain()操作结果:主函数。调用以上的各个函数来引导用户进行长整数的加法运算,加法运算,乘法
7、运算。一、详细设计1.数据结构详细设计typedefstructNode//双向链表的结构体定义{intdata;structNode*prior;structNode*next;}DLNode;双向循环链表的节点由三个部分组成,第一是数据部分data存储此节点的数据,第二是此节点的前驱指针部分*prior指向此节点的前驱,第三是此节点的后继指针部分*next指向此节点的后继。数据部分我们约定它为整形变量,前驱后继指针均为结构体Node类型。2.链表初始化函数:voidListInitiate(DLNode**head)//
8、双向链表的初始化{if((*head=(DLNode*)malloc(sizeof(DLNode)))==NULL)exit(0);(*head)->prior=*head;(*head)->next=*head;}初始化之前需要定义一个类型为Node型的头结点变量,经过函数后完成链表的初
此文档下载收益归作者所有