解题思路:先将短的数组与长数组相加,当短数组结束时退出;再将长数组余下的高位投入要输出的数组中。
注意事项:因为是在字符串中进行所以一定注意转数字时+或者-48;
还要考虑进位问题,特别是最后一次的进位。
参考代码:
#include<stdio.h>
#include<string.h>
int main()
{
char a[101],b[101],c[103],*m=a,*n=b,*k=a,*k1=b;
int s=0,i=0,w=0;//'w'为进位符
scanf("%s%s",a,b);
while(*m)m++;m--;
while(*n)n++;n--;//走到每个字符串的最后一个数,也就是指向个位
while(m>=a&&n>=b)
{
s=*m+*n+w-48-48;
c[i++]=s%10+48;
w=s/10;
m--;n--;
}//将短的一方字符串同加先计算完
if(strlen(a)>strlen(b)){k=m;k1=a;}
else {k=n;k1=b;}//指针'k'一定指向长的数值,并用k1记住长数组的首地址
while(k>=k1)
{
c[i++]=(*k-48+w)%10+48;
w=(*k-48+w)/10;
k--;
}//将余下的长的一个一个的投入c数组
if(w!=0)c[i]=w+48;//考虑到最后一次进位的可能
m=c;
while(*m)m++;m--;
while(m>=c){printf("%c",*m);m--;}//因为无法提前知道输出长度,所以用指针反向输出答案
return 0;
}
感觉代码对你有用的话,留下你的赞赞吧(#^.^#)
0.0分
0 人评分
分糖果 (C++代码)浏览:1537 |
母牛的故事 (C语言代码)浏览:478 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:537 |
永远的丰碑 (C语言代码)浏览:608 |
剪刀石头布 (C语言代码)浏览:1519 |
C语言程序设计教程(第三版)课后习题8.2 (C语言代码)浏览:1108 |
班级人数 (C语言代码)浏览:980 |
C语言程序设计教程(第三版)课后习题1.6 (C语言代码)浏览:745 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:455 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:456 |