



下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、实验二 线性表的应用 (2 学时 ) 一、实验目的 : 掌握线性表的基本结构与操作方法 , 培养学生灵活使用结构解决实际问题的能 力。 二、实验内容 : 设计一个 100 位以内的长整数加减运算的程序。 三、实验要求 : 1, 输入输出要求 : 每四位一组 , 组间用逗号分隔 ; 2, 加与减分别用不同的程序实现 3, 程序应考虑输入数据的符号 四、参考程序 /* 设计一个 100 位以内的长整数加减运算的程序。 实验要求 : 1,输入输出要求 :每四位一组 ,组间用逗号分隔 ; 2,程序应考虑输入数据的符号 */ #include #include #include #include #in
2、clude #define LEN sizeof(struct student) struct student int score; struct student *next; ; int lenm,lenn,lensum;/m 与 n 的长度 void main() struct student *creat(int *d,int *len); void print(struct student *head); struct student *add(struct student *m,struct student *n); struct student *sub(struct studen
3、t *m,struct student *n); int compare(struct student *m,struct student *n); struct student *m,*n,*sum; int s1,s2,s3,k; char ch; printf( 输入第一个数 :n); m=creat(/ 输入第一个数放在链表 m 中 ,s1 为其符号 printf(n 选择运算 ,输入或 :); scanf(%c,getchar(); printf(n 输入第二个数 :n); n=creat(/ 输入第一个数放在链表 n 中 ,s2 为其符号 k=compare(m,n);/k=1 则
4、 mn,k=-1 则 m0)s3=s1;sum=add(m,n); else if(s10sum=sub(m,n);/m0,n|n|,m+n=m-|n| if(s10sum=sub(n,m);/m0,n0,m|n|,m+n=-(|n|-m) if(s10sum=sub(m,n);/m0,|m|n|,m+n=-(|m|-n) if(s10sum=sub(n,m);/m0,|m|n|,m+n=n-|m| if(k=0) s3=0; /endif+ if(ch=-)/ 减法运算 if(s1*s20sum=sub(m,n);/m0,n0,mn,m-n=m-n if(s10sum=sub(n,m);/m
5、0,n0,mn,m-n=-(n-m) if(s10sum=sub(m,n);/m0,n|n|,m-n=-(|m|-|n|) if(s10sum=sub(n,m);/m0,n0,|m|0) printf( 结果为 :+);print(sum); if(s3score=0; p1-next=NULL; len=strlen(c); for(;i=0/ 将 s 转换成整数 p1-next=p2;/ 插入到链表头 p2=p1; *n=k; return(p1); ,p1 指向新建立的结点 struct student *add(struct student *m,struct student *n)/
6、 加法运算 struct student *p1,*p2,*head;/p2 指向链表上最后一个结点 int sumb=0,n1,n2,n3; n1=lenm;n2=lenn; n3=n1n2?n1:n2; p2=p1=(struct student *)malloc(LEN); p1-score=(m-score+n-score)%10000; sumb=(m-score+n-score+sumb)/10000; p2-next=NULL; head=p2; m=m-next;n=n-next; while(m!=NULL p1-score=(m-score+n-score+sumb)%10
7、000; sumb=(m-score+n-score+sumb)/10000; p1-next=NULL; p2-next=p1; p2=p1; m=m-next; n=n-next; while(m!=NULL) p1=(struct student *)malloc(LEN); p1-score=(m-score+sumb)%10000; sumb=(m-score+sumb)/10000; p1-next=NULL; p2-next=p1; p2=p1; m=m-next; while(n!=NULL) p1=(struct student *)malloc(LEN); p1-score
8、=(n-score+sumb)%10000; sumb=(n-score+sumb)/10000; p1-next=NULL; p2-next=p1; p2=p1; n=n-next; lensum=n3; return head; /endadd struct student *sub(struct student *m,struct student *n)/ 减法运算 struct student *p1,*p2,*head; int sumb=0,n1,n2; n1=lenm;n2=lenn; p2=p1=(struct student *)malloc(LEN); if(m-score
9、=n-score)p1-score=m-score+sumb-n-score; elsep1-score=m-score-n-score+10000;sumb=-1; p1-next=NULL; m=m-next;n=n-next; head=p2; while(n) p1=(struct student *)malloc(LEN); p1-next=NULL; if(m-score+sumb=n-score) p1-score=m-score+sumb-n-score; sumb=0; else p1-score=m-score+sumb-n-score+10000; sumb=-1; p2
10、-next=p1; p2=p1;m=m-next;n=n-next; while(m) p1=(struct student *)malloc(LEN); p1-next=NULL; p1-score=m-score+sumb; sumb=0; p2-next=p1; p2=p1;m=m-next; lensum=n1; return head; /endsub int compare(struct student *m,struct student *n)/ 比较两数大小 int i=0; if(lenmlenn) return 1; if(lenmscoren-score) i=1; if(m-scorescore) i=-1; m=m-next;n=n-next; retu
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 【正版授权】 IEC 60598-2-1:1979 EN-D Luminaires. Part 2: Particular requirements. Section One: Fixed general purpose luminaires
- 【正版授权】 IEC 60335-2-71:2002/AMD1:2007 FR-D Amendment 1 - Household and similar electrical appliances - Safety - Part 2-71: Particular requirements for electrical heating appliances
- 校园食品安全知识培训课件
- 北山公园卫生知识培训课件
- 2026届湖北省宜昌市二中化学高二第一学期期末达标检测模拟试题含答案
- 大肠心理测试题及答案
- 光纤光学试题及答案
- 江苏海事面试题及答案
- 校园反恐安全知识培训课件
- 位移法考试题及答案
- 高考3500词汇表(完整版)
- JJF1059.1测量不确定度评定培训讲演稿
- 人教版新目标初中英语Go-for-it!单词大全(音标齐全-已反复校对-单词分类-便于识记)
- 人体解剖学与组织胚胎学(高职)全套教学课件
- 二年级上册语文教材解读-
- 学校文印室及时服务方案
- 毛振明《体育教学论》(第3版)配套题库【课后习题+专项题库】
- 集团公司内部资金调剂管理办法
- 思想道德与法治课件:专题五在实现中国梦的实践中放飞青春梦想
- 新人教A必修一《集合》课件
- 复用器械处理流程
评论
0/150
提交评论