付费下载
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*实践教学#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*#J*兰州理工大学技术工程学院2013年春季学期数据结构课程设计目:长整数的加减运算专业班级:计算机科学与技术一班姓名:郭利强学号:11730108指导教师:王连相成绩:计算机科学与技术专业数据结构课程设计任务书(11级)题目:长整数的加减运算学生姓名:郭利强学号:11730108班级:11级计算机科学与技术一班题目类型:软件工程(R)指导教师:王连相一. 题目简介该
2、设计要求学生设计程序,实现两个任意长的整数求和及差的运算问题。通过该题目的设计过程,可以加深理解线性表的逻辑结构、存储结构,掌握线性表上基本运算的实现,进一步理解和熟练掌握课本中所学的各种数据结构,学会如何把学到的知识用于解决实际问题,培养学生的动手能力。二. 主要任务第一部分:基本算法实现1、线性结构基本算法实现(指导老师根据题目指定);2、树型结构基本算法实现(指导老师根据题目指定);3、图型结构基本算法实现(指导老师根据题目指定);4、查找基本算法实现(指导老师根据题目指定);5、排序基本算法实现(指导老师根据题目指定);第二部分:指定题目的设计与实现1、查阅文献资料,一般在3篇以上;2
3、、建立数据的逻辑结构和物理结构;3、完成相应算法的设计;4、完成测试工作;5、撰写设计说明书;6、做好答辩工作。三. 主要内容、功能及技术指标(1) 使用双向循环链表存储长整数,每个结点含一个整型变量,主要功能有:长整数输入(建立双向循环链表)、长整数的加法、长整数的减法及结果的显示输出等;(2) 至少要用10组测试数据,算法对于这些合法的输入数据都能产生满足规格说明要求的结果;(3) 算法对于精心选择的典型、苛刻而带有刁难性的几组输入数据能够得出满足规格说明要求的结果;对算法实现过程中的异常情况能给出有效信息;(4) 任何整型变量的范围是-(215-1)(215-1)。输入和输出形式:按中国
4、对于长整数的表示习惯,每四位一组,组间用逗号隔开,例1,0000,0000,0000;而输入为1,0001,0001和T,0001,0000实现加法时,应输出1;(5) 较高要求:使程序在整型量范围是-(2n-1)(2n-1)的计算机上都能有效地运行。其中,n是由程序读入的参量。四. 提交的成果1. 设计说明书一份,内容包括:1) 中文摘要100字;关键词3-5个;2) 序言;3) 采用类c语言定义相关的数据类型4) 各模块的伪码算法5) 函数的调用关系图6) 调试分析a、调试中遇到的问题及对问题的解决方法;b、算法的时间复杂度和空间复杂度。7)测试结果8)源程序(带注释)9)设计总结、参考文
5、献、致谢等。2. 刻制光盘一张。五. 主要参考文献1. 严蔚敏,吴伟民.数据结构(C语言版)清华大学出版社.2. 严蔚敏,吴伟民.数据结构题集(C语言版)清华大学出版社.3.DATASTRUCTUREWITHC+.WilliamFord,W订liamTopp.清华大学出版社(影印版).4.谭浩强.c语言程序设计.清华大学出版社.5数据结构与算法分析(Java版),APracticalIntroductiontoDataStrueturesandAlgorithmAnalysisJavaEditionCliffordA.Shaffer,张铭,刘晓丹译电子工业出版社2001年1月六、各阶段时间安排
6、(共2周)周次日期内容地点第1周星期一教师讲解设计要求,准备参考资料教室星期二分析设计要求,进行数据结构及算法设计教室、实验室星期四五算法设计,编程实现实验室第2周星期一编程上机实现、测试程序实验室星期四五检查程序,答辩实验室2013年6月28日摘要数据结构解决实际应用中的问题,将学习的理论知识应用于实践,增强学生解决实际问题的能力。采用的基本数据结构为线性表。计算机存储的数据是有范围限制的,对于超出存储限制的数据无法直接在计算机中计算,为此需要设计相应的程序来完成这种超出范围限制的长整数间的加减运算。实现任意长的整形数进行加减运算的程序,要求完成长整数的加、减运算。在这里长整数没有范围限制,
7、可任意长。运算后的进位、借位等都要进行正确处理,可实现动态的输入,实时的输出。关键字:任意长整数,加、减运算序言课程设计是实践性教学中的一个重要环节,它以某一课程为基础,可以涉及和课程相关的各个方面,是一门独立于课程之外的特殊课程。课程设计是让同学们对所学的课程更全面的学习和应用,理解和掌握课程的相关知识。数据结构是一门重要的专业基础课,是计算机理论和应用的核心基础课程。数据结构课程设计,要求学生在数据结构的逻辑特性和物理表示、数据结构的选择和应用、算法的设计及其实现等方面,加深对课程基本内容的理解。同时,在程序设计方法以及上机操作等基本技能和科学作风方面受到比较系统和严格的训练。在这次程序设
8、计中我选择了长整数的代数计算这个题目,在一般的程序运算中,长整数是无法计算的,因为计算机一次能够运算的位数是有限,一旦整数很长,就需要一个程序来进行多次计算,通过这个程序,可一把一个长整数分成多个普通整数来进行计算,使得长整数也可以进行运算。我编写的这个程序就可以进行加减乘除的运算,各个数据也可以是负数。目录一、概要设计1.1数据结构1.2使用函数二、流程图三、详细设计3.1数据结构详细设计3.2链表初始化函数:3.3计算已知的链表长度:3.4插入函数:3.5绝对值函数:3.6读入数据并插入对应的链表函数:3.7输出函数3.8加法函数(正数加上正数)3.9判断俩正数大小函数:3.10减法函数:
9、3.11整合八种情况函数:3.12主函数:四、调试分析4.1调试过程中遇到的问题五、使用说明和测试结果5.1使用说明5.2测试结果附录设计总结参考文献致谢、概要设计11数据结构此实验采用的数据结构是双向循环链表。这样可以很容易的找到他的前驱以及它的后继。节点采用结构体类型,代码如下:typedefstruetNode/双向链表的结构体定义intdata;struetNode*prior;struetNode*next;DLNode;1.2使用函数1) voidListlnitiate(DLNode*head)操作结果:初始化一个头结点为head的双向循环链表;2) intListLength(
10、DLNode*head)操作结果:计算以head为头结点的链表的长度3) intListlnsert(DLNode*head,inti,intx)操作结果:将节点数据为x的节点插到第i个位置上去。4) intabs(intx)操作结果:绝对值函数,返回x的绝对值。5) intInputNumber(DLNode*head)操作结果:将从键盘中接收数据并把得到的数据存入以head为头结点的链表中。四位一存,中间以逗号区分,结束符为分号。6) voidOutputNumber(DLNode*head,intsign)操作结果:将以head为头结点的链表中的所有数据输出到显示屏上,7) voidad
11、d(DLNode*headl,DLNode*head2,DLNode*head3)操作结果:实现正数加正数的加法操作。8) intchange(DLNode*headl,DLNode*head2)操作结果:判断存在俩个链表中的数的大小,如何headl中的数大于head2中的数那么返回值为0,反之返回值为1,相等时返回值为2;9) voidminus(DLNode*head1,DLNode*head2,DLNode*head3)操作结果:计算正数减正数的减法运算。10) voidyunsuan(DLNode*head1,DLNode*head2,DLNode*head3,charch)操作结果:
12、正数,负数,加法,减法。计算式共分为八种运算,在这之前我已经实现了二种运算,那么这个函数就是把这八种运算按照一定的规则转化成已经实现的二种运算来实现完整的加减法运算。11) voidmain()操作结果:主函数。调用以上的各个函数来引导用户进行长整数的加法运算,加法运二、函数流程图开始输入两位整数数字转化链表情况判断三、详细设计31数据结构详细设计typedefstruetNode/双向链表的结构体定义intdata;struetNode*prior;struetNode*next;DLNode;双向循环链表的节点由三个部分组成,第一是数据部分data存储此节点的数据,第二是此节点的前驱指针部
13、分*prior指向此节点的前驱,第三是此节点的后继指针部分*next指向此节点的后继。数据部分我们约定它为整形变量,前驱后继指针均为结构体Node类型。3.2链表初始化函数:voidListlnitiate(DLNode*head)/双向链表的初始化if(*head=(DLNode*)malloc(sizeof(DLNode)=NULL)exit(0);(*head)->prior二*head;(*head)->next二*head;初始化之前需要定义一个类型为Node型的头结点变量,经过函数后完成链表的初始化即:头节点的前驱指针指向自己,同时他的后继指针也指向自己。3.3计算已知
14、的链表长度:intListLength(DLNode*head)/双向链表的表长DLNode*p=head;intsize=O;while(p->next!二head)p=p->next;size+;returnsize;此函数计算的是已知链表的长度。主要思想:从头结点开始寻找下一个节点,找到计数器加一。直到再次寻找到头结点时停止,计算完毕。3.4插入函数:intListlnsert(DLNode*head,inti,intx)/双向链表的数据插入,i表示是插入的第几个元素DLNode*p,*s;intj;p=head->next;j=0;while(p!二head&
15、&j<i)p=p->next;j+;if(j!=i)printf("n插入位置不合法!");return0;if(s=(DLNode*)malloc(sizeof(DLNode)=NULL)exit(0);s->data二x;s->prior二p->prior;/插入p>prior>next二s;s->next二p;p>prior=s;return1;此函数是已知一双向链表实现在第i个位置插入data为x的节点。函数需要注意的是在什么位置插入才是合法的,在就是在该节点指针时的顺序不要搞错。3.5绝对值函数:int
16、abs(intx)if(x<0)returnx;elsereturnx;此函数是实现求一个整数的绝对值。设计这么一个函数主要是考虑到在存储负数的时候头结点应该变为正整数,然后通过其他手段变相实现那种运算。3.6读入数据并插入对应的链表函数:intInputNumber(DLNode*head)/读入输入的数据intinput,i=0;/第i个节点charc;scanf("%d%c",&input,&c);while(1)if(input<0&&i=0)/输入数为负且是第一个节点head->data=O;/将长整数的符号保存在
17、头结点中/input二abs(input);/取输入数字的绝对值Listlnsert(head,i,input);/插入数据elseif(input>=0&&i=0)/输入数为正且是第一个节点head->data=l;/将长整数的符号保存在头结点中Listlnsert(head,i,input);/插入数据elseif(head->next->data>=0)Listlnsert(head,i,input);/非第一个节点else/input二-l*input;Listlnsert(head,i,input);i+;if(c二二;)break;/遇
18、到数据输入完成标志,跳出循环scanf("%d%c",&input,&c);return1;此函数实现的是从键盘上得到数据根据三种情况进行不同的处理,判断是否是头结点,判断是否是整数,判断输入的字符是否是“;分号。并且如果是正整数它的头结点data等于1否则为0。3.7输出函数/从表尾输出数据元素voidOutputNumber(DLNode*head,intsign)DLNode*r二head>next;while(r->data=0&&r!=head->prior)r=r->next;if(sign=l)print
19、f("结果是:");elseprintf("结果是:-");printf("%d",r->data);r=r->next;while(r!二head)if(r->data<10)printf(",000");printf("%d",r->data);elseif(r->data<100)printf(",00");printf("%d",r>data);elseif(r->data<1000)pr
20、intf(",O");printf("%d",r->data);elseprintf(",%d",r->data);r=r->next;printf("n");此函数实现的是将最后的结果输出到显示屏上,经过判断数据的正负和数据的范围来进行不同的处理,以保证在显示屏上显示的是正确的格式。3.8加法函数(正数加上正数)voidadd(DLNode*headl,DLNode*head2,DLNode*head3)intz=0;inte;DLNode*pl,*p2;pl二headl>prior;p2
21、=head2->prior;while(p1!=head1&&p2!=head2)e=p1>data+p2>data+z;if(e>=10000)z=l;e=e%10000;elsez=0;Listlnsert(head3,0,e);pl二pl->prior;p2二p2->prior;if(p1=head1&&p2!=head2)while(p2!=head2)e=p2->data+z;if(e>=10000)z=1;e=e%10000;elsez=0;Listlnsert(head3,0,e);p2=p2->
22、;prior;if(z=1)Listlnsert(head3,0,z);elseif(p1!=head1&&p2=head2)while(p1!=head1)e二pl->data+z;if(e>=10000)z=1;e=e%10000;elsez=0;Listlnsert(head3,0,e);p1=p1->prior;if(z=1)Listlnsert(head3,0,z);elseif(z=1)Listlnsert(head3,0,z);此函数实现的是两个正数之间的相加运算,主要的算法和我们手算加法是一样的,首先设置一个进位计数的变量,根据存储的特点从低位
23、开始相加带上进位即可得出相应的位和,最后更新进位变量。处理边界状况:如果两个链表一样长同时他们最高位在计算完成时仍然会有进位,那么应该考虑到在数据的更高位插入一个1表示最后的计算结果,这样才可以保证数据的完整性。3.9判断俩正数大小函数:intchange(DLNode*head1,DLNode*head2)intlength1,length2,r=2;length1二ListLength(head1);length2二ListLength(head2);DLNode*p1,*p2;pl二headl>next;p2二head2->next;if(length1>length2
24、)r=0;returnr;elseif(length1<length2)r=1;returnr;elseinti=0;for(i=0;i<length1;i+)if(p1->data>p2->data)r=0;returnr;break;elseif(p2->data>p1->data)r=1;returnr;break;elsep1=p1->next;p2=p2->next;r=2;returnr;此函数实现的是判断俩个正数的大小。考虑俩正数的在链表中所占存储单元的多少,多的一定大,当他们一样长时,一位一位的比较直到找到一个节点中的
25、data比另一个链表的对应节点的data大为止。如果最后仍是一样大那么这两个数就是一样大的。返回值为自己约定的参数r等于2表示俩数一样大,等于1表示第二个数大,等于0表示第一个数大。310减法函数:voidminus(DLNode*head1,DLNode*head2,DLNode*head3)intz=0,x=T;inte;DLNode*p1,*p2;p1=head1->prior;p2=head2->prior;x二change(head1,head2);if(x=0)while(p1!=head1&&p2!=head2)pl->data二pl->d
26、ata+z;if(pl->data>二p2->data)e=p1->data-p2->data;Listlnsert(head3,0,e);pl二pl->prior;p2二p2->prior;z=0;elsee=10000+p1->data-p2->data;Listlnsert(head3,0,e);p1=p1->prior;p2=p2->prior;z=-1;p1->data二p1->data+z;while(p1!=head1)e=p1->data;Listlnsert(head3,0,e);p1=p1-
27、>prior;elseif(x=1)p2=head1->prior;p1=head2->prior;while(p1!=head2&&p2!=head1)pl->data二pl->data+z;if(pl->data>二p2->data)e=p1->data-p2->data;Listlnsert(head3,0,e);pl二pl->prior;p2二p2->prior;z=0;elsee=10000+p1->data-p2->data;Listlnsert(head3,0,e);p1=p1-&
28、gt;prior;p2=p2->prior;z=-1;p1->data二p1->data+z;while(p1!=head2)e=p1->data;Listlnsert(head3,0,e);p1=p1->prior;head3->next->data二1*head3->next->data;head3>next->data=O;else此函数实现的是两个正数的减法运算。整个函数分为俩大部分,第一部分处理第一个数大于第二个数,第二部分是处理第二个数大于第一个数。在这个为题上我们想了好长时间,感觉俩部分可以结合成一部分,但是由于知
29、识所限没有想出更好的办法,这使得代码量增加了足足一倍之多。仍然模仿手算减法,先找到俩数字中最大的那个,用大的减去小的。最后判断符号位。311整合八种情况函数:voidyunsuan(DLNode*headl,DLNode*head2,DLNode*head3,charch)DLNode*pl,*p2;pl二headl>next;p2二head2->next;if(head1->data=1&&head2->data=1)if(ch二二'+')add(head1,head2,head3);elseminus(head1,head2,head
30、3);elseif(head1->data=1&&head2->data=0)if(ch二二'+')head2>next->data*=T;minus(head1,head2,head3);head2>next>data*=1;add(headl,head2,head3);elseif(headl->data=O&&head2->data=l)if(ch二二'+')head1->next->data*=T;minus(head2,headl,head3);elsehead
31、1->next->data*=T;head2>next->data*=T;add(headl,head2,head3);head3>next>data*=T;elseif(ch二二'+')head1>next>data*=T;head2>next>data*=T;add(headl,head2,head3);head3>next>data*=T;elseheadl>next->data*=l;head2>next->data*=l;minus(head2,headl,head3);此
32、函数实现的是八种情况的整合。八种情况分别是正数加正数、正数加负数、正数减正数、正数减负数、负数加负数、负数加正数、负数减正数、负数减负数。此函数调用已经做好的正数加正数和正数减正数函数判断符号位,根据一定的规则实现八种运算。312主函数:voidmain()charch,chl;while(1)/intw=-1;DLNode*a,*b,*c;Listlnitiate(&a);Listlnitiate(&b);Listlnitiate(&c);printf("请输入数A(以分号结束):");InputNumber(a);/printf("n&
33、quot;);printf("请输入数B(以分号结束):");InputNumber(b);/w=change(a,b);printf("请选择操作符:<+,->:n");scanf("%s",&chi);if(chi二二'+'|ch1二二)yunsuan(a,b,c,ch1);OutputNumber(c,1);elseif(ch1=二'*')chengfa(a,b);elseprintf(“此版本不支持%c运算",ch1);printf("要继续吗?(y/n)
34、:");scanf("%s",&ch);if(ch='Y'|ch='y')printf("n");continue;elseexit(0);此函数是主函数。主要的作用是为用户做一个提示,如何完成自己想要的运算。同时调用各个函数实现运算。四、调试分析4.1调试过程中遇到的问题在函数编写之前我首先写出了所有函数的框架以及各个函数之间的关系,根据逐步求精的思想来完善整个程序。即使是这样我仍然遇到了不少错误。例如:在实现正数减正数时,我一开始没有分为以上所说的俩个部分,而是把俩个部分整合到一起实现一个大函数,但是
35、在我运行调试时结果大不如人意,出现的都是匪夷所思的数字,我根本就推算不出这些数字是怎么来的。没有办法我只好在另辟途径来完成函数的实现。于是我就分作两个部分来实现,这样逐步追踪可以使思绪更加清晰,所付出的代价是代码量增加。五、使用说明和测试结果5.1使用说明用户在使用该程序时,只需按照程序中的规定进行即可实现长整数的加减运算,具体使用步骤如下:1)点击运行按钮,在dos窗口下按照规定输入的数字需要从低位开始数四位一组用逗号隔开。输入第一个数字。2)同上输入第二个数;3)选择要对这两个长整数进行的运算。4)两个操作数与运算符选择完毕后,按回车键即可得到运算结果。5.2测试结果5)考虑边界数字,输入
36、0和0做加法运算,输出“0”结果如下图:请输入数A(以分号结束):0;'C:UsersAdiministratorDocumentsC-FreeT巳mp未命名1.exe"请输入数E(以分号结束):0;请连择換作蒋:+厂,:结果是:0要继续吗?(y/n):情况),结果如下图:7)考虑减法进位并且数A小于数B,结果如下图:8)考虑减法进位并且数A大于数B,结果如下图:9)连续输入两次数据测试;如下图:"C:UsersAdministratorDocumentsC-FreeT未命名1.exe"请输入数A(以分号结束):1,0000,0000,0000;请输入数班
37、以分号结束):9999,9999;请选择操作符:+,-,:I+结果是:1,0000,9999,9999I要继续吗?(y/n):yI请输入数A(以分号结束):1,0001,0001;I请输入数班以分号结束):1,0001,0000;请连择換作蒋:+,-,:II结果是:1I要继续吗?(y/n):10)较高要求IM"C:UsersAdminisiratorDocumentsC-FreeTempVfc命窖1.exe"fH_鼻请输入数A(以分号结束):1000,0000,0000,0000,0000,0000;请蠕入薮E(以分号结耒):3000,0000,0000,0000,0000
38、,0000;I请连择接作蒋:结果是:-2000,0000,0000,0000,0000,0000要继续吗?(y/n):附录程序的完整代码清单:#include<stdio.h>#include<stdlib.h>#include<malloc.h>typedefstructNode/双向链表的结构体定义intdata;structNode*prior;structNode*next;DLNode;voidListlnitiate(DLNode*head)/双向链表的初始化if(*head=(DLNode*)malloc(sizeof(DLNode)=NULL
39、)exit(0);(*head)->prior=*head;(*head)->next二*head;intListLength(DLNode*head)/双向链表的表长DLNode*p=head;intsize=0;while(p->next!二head)p=p->next;size+;returnsize;intListlnsert(DLNode*head,inti,intx)/双向链表的数据插入,i表示是插入的第几个元素DLNode*p,*s;intj;p二head>next;j=0;while(p!二head&&j<i)p=p->
40、next;j+;if(j!=i)printf("n插入位置不合法!");return0;if(s=(DLNode*)malloc(sizeof(DLNode)=NULL)exit(0);s->data二x;s->prior=p->prior;/插入p->prior->next二s;s->next二p;p->prior=s;return1;intabs(intx)if(x<0)return-x;elsereturnx;intInputNumber(DLNode*head)/读入输入的数据intinput,i=O;/第i个节点ch
41、arc;scanf("%d%c",&input,&c);while(1)if(input<0&&i=0)/输入数为负且是第一个节点head->data=O;/将长整数的符号保存在头结点中/input二abs(input);/取输入数字的绝对值Listlnsert(head,i,input);/插入数据elseif(input>=0&&i=0)/输入数为正且是第一个节点head->data=l;/将长整数的符号保存在头结点中Listlnsert(head,i,input);/插入数据elseif(head
42、->next->data>=0)Listlnsert(head,i,input);/非第一个节点else/input二-l*input;Listlnsert(head,i,input);i+;if(c='')break;/遇到数据输入完成标志,跳出循环scanf("%d%c",&input,&c);return1;/从表尾输出数据元素voidOutputNumber(DLNode*head,intsign)DLNode*r二head>next;while(r->data=0&&r!=head-&g
43、t;prior)r=r->next;if(sign=l)printf("结果是:");elseprintf("结果是:-");printf("%d",r->data);r=r->next;while(r!二head)if(r->data<10)printf(",000");printf("%d",r->data);elseif(r->data<100)printf(",00");printf("%d",r&g
44、t;data);elseif(r->data<1000)printf(",O");printf("%d",r->data);elseprintf(",%d",r->data);r=r->next;printf("n");voidadd(DLNode*headl,DLNode*head2,DLNode*head3)intz=0;inte;DLNode*pl,*p2;pl二headl>prior;p2=head2->prior;while(p1!=head1&&
45、p2!=head2)e=p1>data+p2->data+z;if(e>=10000)z=1;e=e%10000;elsez=0;Listlnsert(head3,0,e);p1=p1>prior;p2=p2>prior;if(pl二二headl&&p2!=head2)while(p2!=head2)e=p2->data+z;if(e>=10000)z=1;e=e%10000;elsez=0;Listlnsert(head3,0,e);p2=p2->prior;if(z=1)Listlnsert(head3,0,z);elseif
46、(p1!=head1&&p2=head2)while(p1!=head1)e=p1->data+z;if(e>=10000)z=1;e=e%10000;elsez=0;Listlnsert(head3,0,e);p1=p1->prior;if(z=1)Listlnsert(head3,0,z);elseif(z=l)Listlnsert(head3,0,z);intchange(DLNode*headl,DLNode*head2)intlengthl,length2,r=2;lengthl二ListLength(headl);length2二ListLengt
47、h(head2);DLNode*p1,*p2;p1=head1->next;p2=head2->next;if(length1>length2)r=0;returnr;elseif(length1<length2)r=1;returnr;elseinti=0;for(i=0;i<length1;i+)if(p1->data>p2->data)r=0;returnr;break;elseif(p2->data>pl->data)r=1;returnr;break;elsep1=p1->next;p2=p2->next;
48、r=2;returnr;voidyunsuan(DLNode*headl,DLNode*head2,DLNode*head3,charch)DLNode*pl,*p2;p1=head1->next;p2=head2->next;if(head1->data=1&&head2->data=1)if(ch二二'+')add(head1,head2,head3);else(head1,head2,head3);elseif(head1->data=1&&head2->data=0)if(ch二二'+'
49、)head2>next->data*=T;(headl,head2,head3);elsehead2>next>data*=T;add(headl,head2,head3);elseif(head1>data=O&&head2>data=l)if(ch二二'+')head1>next>data*=T;(head2,headl,head3);elsehead1>next>data*=T;head2>next>data*=T;add(headl,head2,head3);head3>next>data*=T;elseif(ch二二'+')head1>next>data*=l;head2>next>data*=l;add(headl,head2,head3);head3>next->data*=T;elsehead1->next->data*=l;he
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026年健康管理服务与保险结合
- 2026年游戏界面设计原则与实战技巧
- 2026年氧气传感器定期校验与更换周期
- 2026年在建工程脚手架安全搭设规范
- 上海立达学院《安全管理与法规》2025-2026学年第一学期期末试卷(A卷)
- 2026年企业年度培训预算编制与管理指南
- 上海立达学院《Android 移动应用开发课程设计》2025-2026学年第一学期期末试卷(B卷)
- 上海立信会计金融学院《阿拉伯国情》2025-2026学年第一学期期末试卷(A卷)
- 2026年化工企业生产过程危化品安全控制培训
- 上海立信会计金融学院《安全工程专业概论》2025-2026学年第一学期期末试卷(B卷)
- 小企业考勤管理制度模板
- 12J201平屋面建筑构造图集(完整版)
- 冀少版一年级下册第2单元《火车开啦》教学设计
- 项目风险记录及跟踪表
- 康复医学科诊疗指南与规范
- FZ∕T 73037-2019 针织运动袜行业标准
- 持续照料养老社区建设指南
- 《三才绝学》聂枭九部系列之一
- 保险行业系统生态图分析报告
- 2018劳动合同北京市劳动合同书样本劳动和社会保障局监制
- 《中华人民共和国标准设计施工总承包招标文件》(2020年版)
评论
0/150
提交评论