* * × * * = * * *
它表示:两个两位数字相乘,结果是3位数。其中的星号(*)代表任意的数字,可以相同,也可以不同,只要不是在首位的就可以是0。当然,满足这个要求的算式很多,但我们还有如下的要求:
所有星号所代表的数字全都是奇数。满足这个要求的算式就不多了。
比如:13 x 15 = 195
题目的任务是:编写程序,找到所有可能的情况。
输出的结果中,每个情况占用1行,不需要考虑不同情况如何排序问题。每行的格式如:
13 x 15 = 195
其中乘号用“x”表示。
#include <iostream>
using namespace std;
int main()
{
int A[5]= {1,3,5,7,9};
for(int a1=0; a1<5; a1++)
for(int a2=0; a2<5; a2++)
for(int b1=0; b1<5; b1++)
for(int b2=0; b2<5; b2++)
{
int a=10*A[a1]+A[a2];
int b=10*A[b1]+A[b2];
int mul=a*b;
if(mul/1000==0)
{
int c1=mul%10,c2=mul/10%10,c3=mul/100;
if(c1%2==1&&c2%2==1&&c3%2==1)
cout<<a<<" * "<<b<<" = "<<mul<<endl;
}
}
return 0;
}