天行九歌mp3下载:求两个超长正整数的和(C语言),求助,谢谢!

来源:百度文库 编辑:中科新闻网 时间:2024/04/28 21:59:12
【问题描述】
编写程序实现两个超长正整数(每个最长80位数字)的加法运算。

【输入形式】

从键盘读入两个整数
1. 第一行是超长正整数A;
2. 第二行是超长正整数B;

【输出形式】
输出只有一行,是两个长整数的运算结果,从高到低依次输出各位数字。各位数字紧密输出。
算法提示:

1.用字符串输入两个超长整数,分别存放在两个字符串中,每一位对应一个字符串中的字符。
2.以较短的超长整数为基准,从低位到高位,对应位转换成数字后相加,再加上前一位相加的进位,得到的和模上10再转换为字符即为当前位,得到的和整除10即为当前位的进位。将计算得到的每一位保存到结果字符数组。
3.将较长字符串的剩余位加上最后一个进位移到结构数组后面。
4.将结果数组反序输出(去掉高位多余的0)。
【输入样例】

134098703578230056
234098

【输出样例】
134098703578464154

【样例说明】
进行两个正整数加法运算,134098703578230056 + 234098 = 134098703578464154。

请问这个要怎么写啊?请大师帮忙啊!谢谢哈!

#include<stdio.h>
#include<string.h>

typedef struct
{
short number[384];
int length;
} BigNumber;

void ADD(BigNumber * a,BigNumber * b,BigNumber * c)
{
int i,aa,bb,cc=0;
for(i=0;i<a->length||i<b->length||cc!=0;++i) {
aa=i<a->length?a->number[i]:0;
bb=i<b->length?b->number[i]:0;
cc+=aa+bb;
c->number[i]=cc%10;
cc/=10;
}
c->length=i;
}

void init(BigNumber * b,char * a)
{
int i,length=strlen(a);
for(i=length-1;i>=0;--i) b->number[i]=a[length-i-1]-'0';
b->length=length;
}

void print(BigNumber * a)
{
int i=a->length==0?0:a->length-1;
for(;i>=0;--i) printf("%d",a->number[i]);
printf("\n");
}

int main()
{
char tmp[125];
BigNumber a,b,c;
scanf("%s",tmp); init(&a,tmp);
scanf("%s",tmp); init(&b,tmp);
ADD(&a,&b,&c);
print(&c);
return 0;
}

#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 *addint1(NODE *p,NODE *q); /*完成加法操作返回指向*p+*q结果的指针*/
void printint(NODE *s);
NODE *inputint(void);

void 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('\n');
printf("S2=");
printint(s2); putchar('\n');
s=addint1(s1,s2); /*求和*/
printf("S1+S2="); printint(s); putchar('\n');
}

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 *addint1(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())!='\n') /*输入整数,按字符接收数字*/
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));
}
}
}

#include<stdio.h>
#include<string.h>
void Format(char* ch)
{
char temp[101];
int i,j,mark=0,len=strlen(ch);
for(i=0;i<strlen;i++)
if(ch[i]!='0'){mark=i;break;}
else continue;
for(i=mark,j=0;i<len;i++,j++)
temp[j]=ch[i];
temp[j]=0;
strcpy(ch,temp);
}
void Add(char *ch1,char *ch2)
{
int vlen=strlen(ch1),vvlen=strlen(ch2);
char temp[101];
int j;
int maxlen=(vlen>vvlen) ? vlen :vvlen;
int minlen=(vlen>vvlen) ? vlen :vlen;
int carry=0;
for(j=0;j<maxlen;j++)
{
int d1=(j>vlen-1)?0:ch1[vlen-j-1]-'0';
int d2=(j>vvlen-1)?0:ch2[vvlen-j-1]-'0';
int digitsum=d1+d2+carry;
if(digitsum>=10)
{digitsum-=10;carry=1;}
else carry=0;
temp[j]=digitsum+'0';
}
if(carry==1)
temp[j++]='1';
temp[j]='\0';
strrev(temp);
puts(temp);
}
main() {
char A[100],B[100],C[101];
gets(A);
gets(B);
Format(A);
Format(B);
Add(A,B);
getch();
}