线性链表地实现及操作.doc

线性链表地实现及操作.doc

ID:56926174

大小:147.00 KB

页数:22页

时间:2020-07-24

线性链表地实现及操作.doc_第1页
线性链表地实现及操作.doc_第2页
线性链表地实现及操作.doc_第3页
线性链表地实现及操作.doc_第4页
线性链表地实现及操作.doc_第5页
资源描述:

《线性链表地实现及操作.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、《数据结构》实验报告学生学生班级学生学号指导老师一.实验容1、设计一个100位以的长整数加减运算的程序。要求如下:输入输出要求:每四位一组,组间用逗号分隔;加和减分别用不同的程序实现程序应考虑输入数据的符号2、用循环链表实现约瑟夫环问题二、需求分析1、使用链表进行超长数据的储存,减法时需要判断减数与被减数的长短关系,再进行对比与运算。在链表前一个节点进行加减来代替进位操作(每个节点数据满十即在前一个节点加一)。使用if(ch>='0'&&ch<='9')语句确保链表中只存放数字。2、建立链表,输入数据,循环输出同时删除

2、节点。三、概要设计1、创建链表储存数据,每个节点存一位,过滤非数字字符如‘,’。调整最高位数字的正负来代表整串数字的正负。进位操作是在前一个节点进行加减。2、创建链表储存数据,设计循环输出并删除节点。四、详细设计1.得到两个链表Number*GetNumber(){Number*p,*q,*List;charch;p=(Number*)malloc(LEN);List=p;List->prior=NULL;List->data=0;//加法时,放最高位进的1,否者999+1=000ch=getchar();while(

3、ch!=''){if(ch>='0'&&ch<='9')//过滤非数字字符{q=(Number*)malloc(LEN);q->data=ch-'0';p->next=q;q->prior=p;p=q;}ch=getchar();}p->next=NULL;List->prior=NULL;returnList;}2.加法分两种情况长度相同与不同Number*JiaFa(Number*num_1,Number*num_2)//返回的数据为逆序{Number*p,*q,*r,*s,*num=NULL;inti=0,j

4、=0;r=num;p=num_1;while(p->next!=NULL){i++;p=p->next;}//i表示number1数字的长度p指向number节点q=num_2;while(q->next!=NULL){j++;q=q->next;}//j表示number2数字的长度q指向number节点s=(Number*)malloc(LEN);s->prior=NULL;s->next=NULL;num=s;while(i--&&j--){s->data=p->data+q->data;if(s->data>9)

5、{s->data-=10;//处理两数相加大于9的情况,后面还有if(i>j)//在长的数据上调整p->prior->data++;elseq->prior->data++;}r=(Number*)malloc(LEN);s->next=r;r->prior=s;s=r;p=p->prior;q=q->prior;}r=s=s->prior;//去掉最后一个没数据的节点free(s->next);s->next=NULL;if(i>j){while(i--){if(p->data>9){p->data-=10;p->p

6、rior->data++;}s=(Number*)malloc(LEN);s->data=p->data;p=p->prior;r->next=s;s->prior=r;r=s;}if(p->data>0){s=(Number*)malloc(LEN);s->data=p->data;r->next=s;s->prior=r;r=s;}}else{while(j--){if(q->data>9){q->data-=10;q->prior->data++;}s=(Number*)malloc(LEN);s->data=q

7、->data;q=q->prior;r->next=s;s->prior=r;r=s;}if(q->data>0){s=(Number*)malloc(LEN);s->data=q->data;r->next=s;s->prior=r;r=s;}}s->next=NULL;//将最后一个next置空returnnum;}3.减法分3中情况:被减数长度大于、小于、等于减数长度Number*JianFa(Number*num_1,Number*num_2)//返回的数据也为逆序{Number*p,*q,*r,*s,*num

8、=NULL;inti=0,j=0;r=num;p=num_1;while(p->next!=NULL)//i表示number1数字的长度p指向number节点{i++;p=p->next;}q=num_2;while(q->next!=NULL)//j表示number2数字的长度q指向number节点{j++;q=q->next;

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。