解题思路:模拟人平时的计算。
注意事项:例如:789*123,那么结果最多为3+3=6,即6位。否则最后无进位,结果为5位。
参考代码:
#include
#include
int main()
{
char a[200],b[200];
int c[200],d[200],e[400]={0};
scanf("%s",a);
scanf("%s",b);
int i,j,t1=strlen(a),t2=strlen(b),le;
for(i=0;i<t1;i++)
{
c[i]=a[t1-1-i]-'0';//将字符型转化为整型
}
for(i=0;i<t2;i++)
{
d[i]=b[t2-1-i]-'0';//因为计算从个位开始,因此要倒回来存储
}
for(i=0;i<t1;i++)
{
for(j=0;j<t2;j++)
{
e[i+j]+=c[i]*d[j]; //先算出每一位的乘积,并将同一位置的相加即个位加个位,十位加十位。。。。
}
}
le=t1+t2-1;//下标最大。
for(i=0;i<le;i++)
{
e[i+1]+=e[i]/10;//加上进位
e[i]%=10;//本位是不能进位的数,即余除于10 的数
}
if(e[le]==0)//判断最后那位是否发生进位,例如123*123=15129 ,e[0]=9,e[1]=2,e[2]=1,e[3]=5,e[4]=1。 e[5]=0,则结果是5位。
{
le--;
}
for(i=le;i>=0;i--)
{
printf("%d",e[i]);//输出
}
return 0;
}
0.0分
1 人评分
C语言程序设计教程(第三版)课后习题8.8 (C语言代码)浏览:628 |
字符串输入输出函数 (Java代码)浏览:1498 |
【蟠桃记】 (C语言代码)浏览:711 |
蛇行矩阵 (C语言代码)浏览:792 |
C语言程序设计教程(第三版)课后习题7.2 (C语言代码)浏览:686 |
C语言程序设计教程(第三版)课后习题11.8 (C语言代码)浏览:910 |
C语言程序设计教程(第三版)课后习题9.10 (C语言代码)浏览:866 |
C二级辅导-同因查找 (C语言代码)浏览:618 |
C二级辅导-统计字符 (C语言代码)浏览:514 |
数组输出 (C语言代码)浏览:749 |