做厌了乘法计算题的佳佳,自创了一种新的乘法运算法则。在这套法则里,A×B等于一个取自A,一个取自B所有数字对的乘积的和。
例如,123*45等于1*4+1*5+2*4+2*5+3*4+3*5=54
本题的任务是,对于给定的数A和B,用新的乘法法则计算A*B的值。
#include <stdio.h>
#include <string.h>
#include <math.h>
int main()
{
int n,m,sum=0,i,j;
int a[10],b[10];
scanf("%d %d",&n,&m);
for(i=0;i<strlen(n);i++)
{
a[i]=n%10;
n=n/10;
}
for(i=0;i<strlen(m);i++)
{
b[i]=m%10;
m=m/10;
}
for(i=0;i<strlen(n);i++)
{
for(j=0;j<strlen(m);i++)
{
sum=sum+a[i]*b[j];
}
}
printf("%d",sum);
return 0;
for(i=0;i<strlen(m);i++)
m是整数,不应该调用strlen
按照你的思路给你修改了下,注意这个程序只支持VC++,gcc需要自己实现 itoa 这个函数
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>
int main()
{
int n1,m1,sum=0,i,j;
int a[10],b[10];
scanf("%d %d",&n1,&m1);
char n[100];
char m[100];
itoa(n1, n, 10);
itoa(m1, m, 10);
for(i=0;i<strlen(n);i++)
{
a[i]=n1%10;
n1=n1/10;
}
for(i=0;i<strlen(m);i++)
{
b[i]=m1%10;
m1=m1/10;
}
for(i=0;i<strlen(n);i++)
{
for(j=0;j<strlen(m);j++) //注意这里是j++不是i++
{
sum=sum+a[i]*b[j];
}
}
printf("%d",sum);
return 0;
}