Codeup 问题 C: 特殊乘法:
题目链接:问题 C: 特殊乘法
问题描述:
写个算法,对2个小于1000000000的输入,求结果。特殊乘法举例:123 * 45 = 14 +15 +24 +25 +34+35
输入格式:
两个小于1000000000的数
输出格式:
输入可能有多组数据,对于每一组数据,输出Input中的两个数按照题目要求的方法进行运算后得到的结果。
输入样例:
24 65
42 66666
3 67
输出样例:
66
180
39
问题代码:
#include <stdio.h>
#include <string.h>
int Fun(char a[],char b[]){
int s=0;
int length1 = strlen(a);
int length2 = strlen(b);
for(int i=0;i<length1;i++){
for(int j=0;j<length2;j++){
s += a[i]*b[j];//这里错了
}
}
return s;
}
char a[20];
char b[20];
int main(){
while(scanf("%s %s",a,b) != EOF){
int sum = 0;
sum = Fun(a,b);
printf("%d\n",sum);
}
return 0;
}
解决方案:
这个题目其实很简单,但是自己做的时候忽略啦char里面存储的数字都是ASCII码值,直接 a[i] * b[j] 就是ASCII码值的计算,所以要把ASCII码转化为数字。采用 " -‘0’ "就可以啦,做的时候傻啦。
#include <stdio.h>
#include <string.h>
int Fun(char a[],char b[]){
int s=0;
int length1 = strlen(a);
int length2 = strlen(b);
for(int i=0;i<length1;i++){
for(int j=0;j<length2;j++){
s += (a[i] -'0')*(b[j] -'0');//转化为数字计算
}
}
return s;
}
char a[20];
char b[20];
int main(){
while(scanf("%s %s",a,b) != EOF){
int sum = 0;
sum = Fun(a,b);
printf("%d\n",sum);
}
return 0;
}