解题思路:模拟人平时的计算。
注意事项:例如: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 人评分
WU-蓝桥杯算法提高VIP-交换Easy (C++代码)浏览:1107 |
WU-小九九 (C++代码)浏览:1681 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:632 |
回文数字 (C语言代码)浏览:2509 |
1025题解浏览:732 |
1124题解浏览:591 |
C语言程序设计教程(第三版)课后习题7.4 (C语言代码)浏览:484 |
简单的a+b (C语言代码)浏览:504 |
C语言程序设计教程(第三版)课后习题10.1 (C语言代码)浏览:759 |
C语言程序设计教程(第三版)课后习题8.3 (C语言代码)浏览:382 |