解题思路: 用数组来计算加法,并进位
注意事项:
参考代码:
#include<stdio.h>
#include <string.h>
int main()
{
char p1[1000],p2[1000];
scanf ("%s",p1);
scanf ("%s",p2);
int a[1000]={0},b[1000]={0},c[100000]={0}; //把所有整形数组都设置为全为0的状态,便于加法
int lp1,lp2;
lp1=strlen(p1);
lp2=strlen(p2);
for (int i=lp1-1,j=0;i>=0;i--,j++){ //将字符数组转化成整形数组,并逆序储存
a[j]=p1[i]-'0';
}
for (int i=lp2-1,j=0;i>=0;i--,j++){ //将字符数组转化成整形数组,并逆序储存
b[j]=p2[i]-'0';
}
for (int i=0;i<(lp1>lp2?lp1:lp2);i++){ //比较两个整形数组长度,用长的进行加法
c[i]=a[i]+b[i];
}
for (int i=0;i<(lp1>lp2?lp1:lp2);i++){ //处理进位
if (c[i]>9){
c[i+1]+=c[i]/10;
c[i]%=10;
}
}
int n=lp1+lp2;
while (c[n]==0&&n>0){ //删除答案数组里的前导0,并且当答案为0时,n>0,保留一位0
n--;
}
for (int i=n;i>=0;i--){ //逆序输出即可
printf ("%d",c[i]);
}
return 0;
}
0.0分
2 人评分
C语言程序设计教程(第三版)课后习题9.6 (C语言代码)浏览:277 |
C语言训练-求PI* (C语言代码)浏览:613 |
1024题解浏览:806 |
星期判断机 (C语言代码)浏览:859 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:401 |
C语言程序设计教程(第三版)课后习题11.3 (C语言代码)浏览:2113 |
C语言训练-求PI* (C语言代码)浏览:335 |
钟神赛车 (C++代码)(标准题解)(与田忌赛马类似)浏览:1728 |
开心的金明浏览:1477 |
小九九 (C语言代码)浏览:648 |