Codeup 问题 C: 特殊乘法

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;
}
上一篇:c++实现数组、字符串中的元素序列全排列


下一篇:C语言学习之我见-strlen()字符串长度函数