观察下面的算式:
* * × * * = * * *
它表示:两个两位数字相乘,结果是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;
}

posted on 2015-04-07 20:34  星斗万千  阅读(166)  评论(0)    收藏  举报