坚果


私信TA

用户名:dotcpp0615334

访问量:4701

签 名:

等  级
排  名 118
经  验 7884
参赛次数 0
文章发表 43
年  龄 0
在职情况 学生
学  校 xx
专  业

  自我简介:

TA的其他文章

解题思路:模拟人平时的计算。

注意事项:例如: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 人评分

  评论区

  • «
  • »