解题思路:
先用两个字符串数组获得输入的值,再将字符串数组转化为int型数组,转化的原理是字符的ASCII码,这里使用了a[i] - '0'的方式,因为字符类型的数字和对应的ASCII码值之间有一个固定的偏移量,通过减去字符'0'的ASCII码值,可以得到对应的数字。
注意事项:
要注意,相加时是从低位加起,我这里在转化为int型数组时,是倒过来赋给数组,
参考代码:
#include<stdio.h> #include<string.h> #define MAXSIZE 2000 int main() { char a[MAXSIZE]={'\0'},b[MAXSIZE]={'\0'}; scanf("%s",a);//不能用gets 切记切记 scanf("%s",b); int len_a=strlen(a); int len_b=strlen(b); int a1[MAXSIZE]={0},count_a=0; int b1[MAXSIZE]={0},count_b=0; for(int i=len_a-1;i>=0;i--) { a1[count_a]=a[i]-'0';//0的ASCII码是48 count_a++; } for(int i=len_b-1;i>=0;i--) { b1[count_b]=b[i]-'0'; count_b++; } int count=0,c=0,i; count=count_a>count_b?count_a:count_b;//比较得出数组长度较长的那个 for(i=0;i<count;i++) { int t=a1[i]+b1[i]+c; a1[i]=t%10; c=t/10;//c是进位 } if(c>0)//如果c最后不为0,说明最高位的两个数字相加后产生了进位,那么需要将进位的值加到结果中的下一位。 { a1[i]=c; } int *p=a1+MAXSIZE-1;//指针从数组末尾开始 while(*p==0&&p>=a1)//元素为0时跳过 { p--; } while(p>=a1) { printf("%d",*p); p--; } return 0; }
0.0分
1 人评分
C语言程序设计教程(第三版)课后习题7.4 (C语言代码)浏览:443 |
C二级辅导-等差数列 (C语言代码)浏览:591 |
矩形面积交 (Java代码)浏览:1220 |
回文串 (C语言代码)浏览:2858 |
C语言程序设计教程(第三版)课后习题6.4 (C语言代码)浏览:603 |
C语言训练-求函数值 (C语言代码)浏览:580 |
【明明的随机数】 (C语言代码)浏览:787 |
大神老白 (C语言代码)浏览:601 |
盐水的故事 (C语言代码)浏览:1528 |
C语言程序设计教程(第三版)课后习题10.2 (C语言代码)浏览:538 |