超长正整数的加法(酷勤网)
99.超长正整数的加法
请设计一个算法来完成两个超长正整数的加法。
*问题分析与算法设计
首先要设计一种数据结构来表示一个超长的正整数,然后才能够设计算法。
首先我们采用一个带有表头结点的环形链来表示一个非负的超大整数,如果从低位开始为每 个数字编号,则第一位到第四位、第五位到第八位...的每四位组成的数字,依次放在链表的第一个、第二个、...结点中,不足4位的最高位存放在链表的最后一个结点中,表头结点的值规定为-1。例如:
大整数“587890987654321”可用如下的带表头结点head的链表表示:
按照此数据结构,可以从两个表头结点开始,顺序依次对应相加,求出所需要的进位后代入下面的运算。具体的实现算法请见程序中的注释。
*程序说明与注释
#include<stdio.h>
#include<stdlib.h>
#define HUNTHOU 10000
typedef struct node{ int data;
struct node *next;
}NODE; /*定义链表结构*/
NODE *insert_after(NODE *u,int num); /*在u结点后插入一个新的NODE,其值为num*/
NODE *addint(NODE *p,NODE *q); /*完成加法操作返回指向*p+*q结果的指针*/
void printint(NODE *s);
NODE *inputint(void);
int main()
{
NODE *s1,*s2,*s;
NODE *inputint(), *addint(), *insert_after();
printf("Enter S1= ");
s1=inputint(); /*输入被加数*/
printf("Enter S2= ");
s2=inputint(); /*输入加数*/
printf(" S1="); printint(s1); putchar(" "); /*显示被加数*/
printf(" S2="); printint(s2); putchar(" "); /*显示加数*/
s=addint(s1,s2); /*求和*/
printf("S1+S2="); printint(s); putchar(" "); /*输出结果*/
}
NODE *insert_after(NODE *u,int num)
{
NODE *v;
v=(NODE *)malloc(sizeof(NODE)); /*申请一个NODE*/
v->data=num; /*赋值*/
u->next=v; /*在u结点后插入一个NODE*/
return v;
}
NODE *addint(NODE *p,NODE *q) /*完成加法操作返回指向*p+*q结果的指针*/
{
NODE *pp,*qq,*r,*s,*t;
int total,number,carry;
pp=p->next; qq=q->next;
s=(NODE *)malloc(sizeof(NODE)); /*建立存放和的链表表头*/
s->data=-1;
t=s; carry=0; /*carry:进位*/
while(pp->data!=-1&&qq->data!=-1) /*均不是表头*/
{
total=pp->data+qq->data+carry; /*对应位与前次的进位求和*/
number=total%HUNTHOU; /*求出存入链中部分的数值 */
carry=total/HUNTHOU; /*算出进位*/
t=insert_after(t,number); /*将部分和存入s向的链中*/
pp=pp->next; /*分别取后面的加数*/
qq=qq->next;
}
r=(pp->data!=-1)?pp:qq; /*取尚未自理完毕的链指针*/
while(r->data!=-1) /*处理加数中较大的数*/
{
total=r->data+carry; /*与进位相加*/
number=total%HUNTHOU; /*求出存入链中部分的数值*/
carry=total/HUNTHOU; /*算出进位*/
t=insert_after(t,number); /*将部分和存入s指向的链中*/
r=r->next; /*取后面的值*/
}
if(carry) t=insert_after(t,1); /*处理最后一次进位*/
t->next=s; /*完成和的链表*/
return s; /*返回指向和的结构指针*/
}
NODE *inputint(void) /*输入超长正整数*/
{
NODE *s,*ps,*qs;
struct number {int num;
struct number *np;
}*p,*q;
int i,j,k;
long sum;
char c;
p=NULL; /*指向输入的整数,链道为整数的最低的个位,链尾为整数的最高位*/
while((c=getchar())!=" ") /*输入整数,按字符接收数字*/
if(c>="0"&&c<="9") /*若为数字则存入*/
{
q=(struct number *)malloc(sizeof(struct number)); /*申请空间*/
q->num=c-"0"; /*存入一位整数*/
q->np=p; /*建立指针*/
p=q;
}
s=(NODE *)malloc(sizeof(NODE));
s->data=-1; /*建立表求超长正整数的链头*/
ps=s;
while(p!=NULL) /*将接收的临时数据链中的数据转换为所要求的标准形式*/
{
sum=0;i=0;k=1;
while(i<4&&p!=NULL) /*取出低四位*/
{
sum=sum+k*(p->num);
i++; p=p->np; k=k*10;
}
qs=(NODE *)malloc(sizeof(NODE)); /*申请空间*/
qs->data=sum; /*赋值,建立链表*/
ps->next=qs;
ps=qs;
}
ps->next=s;
return s;
}
void printint(NODE *s)
{
if(s->next->data!=-1) /*若不是表头,则输出*/
{
printint(s->next); /*递归输出*/
if(s->next->next->data==-1)
printf("%d",s->next->data);
else{
int i,k=HUNTHOU;
for(i=1;i<=4;i++,k/=10)
putchar("0"+s->next->data%(k)/(k/10));
}
}
}
*运行结果
*思考题
请设计完成两个超长正整数的减法、乘法和除法的运算。
转载于:https://blog.51cto.com/4632152/807024
超长正整数的加法(酷勤网)相关推荐
- 119.超长正整数的加法
#include<stdio.h> #include<stdlib.h> #define HUNTHOU 10000 typedef struct node{ int data ...
- 两个超长正整数的加法c语言,二个超长正整数的相加
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 看看这个,定义数组的长度为251,可以实现最长250位的两个整数相加. #include #include main() {int i; char str ...
- c语言两种加法,两个超长正整数的加法
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 #include void main() { int an=-1,bn=-1,max,flag=0; char a[50]={'0'},b[50]={'0 ...
- c语言超长整数加法计算,两个超长正整数的加法
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 #include void main() { int an=-1,bn=-1,max,flag=0; char a[50]={'0'},b[50]={'0 ...
- 超长正整数加法 c语言,两个超长正整数的加法
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 #include void main() { int an=-1,bn=-1,max,flag=0; char a[50]={'0'},b[50]={'0 ...
- 超长整数加法c语言,两个超长正整数的加法
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 #include void main() { int an=-1,bn=-1,max,flag=0; char a[50]={'0'},b[50]={'0 ...
- codesys com库_CODESYS在线库,酷德网镜像站启用
近期由于国内网络问题,造成 stroe.codesys.com 网站无法访问.在线库无法下载.为了不影响广大CODESYS用户的正常使用,酷德网建立stroe.codesys.com的国内镜像站: 主 ...
- 酷动网博客整站源码+Panda PRO主题+7000条完整数据
介绍: 说实话这些资源不值钱 图片应该是没有的,我测试的时候是没有显示 酷动网博客博客已经有7000+文章,模板使用的是pandapro-自己修复了很多 有夜间模式,自适应,有海报,支持多种社区分享 ...
- 酷体网--可以顶(dig)的运动空间
酷体网最近在用户的个人空间中增加了顶的功能,顶的功能来自于dig的理念,最早是用于新闻发布系统,首创的网站是digg.com,这种简洁的表示支持的方式,给用户带来良好的体验.用户通过简单的点击,就可以 ...
- 程序设计大作业---超长正整数的减法
[问题描述] 编写程序实现两个超长正整数(每个最长80位数字)的减法运算. [输入形式] 从键盘读入两个整数,要考虑输入高位可能为0的情况(如00083). 1. 第一行是超长正整数A: 2. 第二行 ...
最新文章
- python将ElasticSearch索引数据读入pandas dataframe实战
- 自然语言处理数据集免费资源开放(附学习资料)
- Android百度地图悬浮窗样式,JS百度地图搜索悬浮窗功能
- ABP vNext分布式事件总线RabbitMQ注意事项
- 【java图文趣味版】数组元素的访问与遍历
- Android 为你的应用程序添加快捷方式【优先级高的快捷方式】
- ubuntu安装字符集
- MIT博士小姐姐的机器学习入门教程开课!碎片时间服用,每周一更 | 资源
- layui表格使用复选框批量删除_LayUI表格批量删除方法
- C++输入变长字符串
- 7天连锁酒店郑南雁:顺势创业者无为管理人
- Axure RP 7.0 注册码
- 极化码的巴氏参数构造算法
- 零库存挑战-分压电阻选择器V1.01【下载地址发布】
- ideaIU的学习一
- python打开ie浏览器_python-IE浏览器调用
- Excel最强玩法!用Excel做“动态日历表”,让你的好记性更牢固!
- ppt如何替换其他mo ban_有没有一个 PPT 技巧让自己觉得人生都亮了?
- java 动漫画图_初学画画怎么把动漫线条画好?
- antd源码-spin解析