关于一道小学奥数题目

#include<cstring>
#include<cstdio>
using namespace std;
/*用于求解 使用123456789  这9个数字组成
xxxx  *  x = xxxx
*/
int main()
{
    unsigned multiplier_four,multiplier_one,product_four,number_record[10],temp;
    //四字乘数大小不会低于1234  不能高于5000
    for(multiplier_four=1234;multiplier_four<5000;multiplier_four++){
        for(multiplier_one=1;multiplier_one<9;multiplier_one++){

         if(multiplier_four * multiplier_one <=9876){
             memset(number_record,0,sizeof(number_record));

             /*for(int i=1;i<10;i++){
                number_record[i] = 0;
             }*/

             product_four = multiplier_four * multiplier_one;

             temp = multiplier_four;
             while(temp){
                    number_record[temp%10] = 1;
                    temp/=10;
                }

             temp = product_four;
             while(temp){
                    number_record[temp%10] = 1;
                    temp/=10;
                }
             number_record[multiplier_one] = 1;

             int i=1;
             while(i<10&&number_record[i]){
                i++;
             }

             if(i==10){
               printf("%u*%u=%u\n",multiplier_four,multiplier_one,product_four);
              }
            }
        }
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值