为jun木而生


私信TA

用户名:seventh

访问量:14507

签 名:

chongchongchong!!!

等  级
排  名 747
经  验 3816
参赛次数 2
文章发表 21
年  龄 0
在职情况 学生
学  校 湖南警察学院
专  业 计科

  自我简介:

emmmmmmm

解题思路:先将短的数组与长数组相加,当短数组结束时退出;再将长数组余下的高位投入要输出的数组中。


注意事项:因为是在字符串中进行所以一定注意转数字时+或者-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 人评分

  评论区

  • «
  • »