蓝桥杯~古堡算式

见证自己成长

福尔摩斯到某古堡探险,看到门上写着一个奇怪的算式:

ABCDE * ? = EDCBA

他对华生说:“ABCDE应该代表不同的数字,问号也代表某个数字!”

华生:“我猜也是!”

于是,两人沉默了好久,还是没有算出合适的结果来。

请你利用计算机的优势,找到破解的答案。

把 ABCDE 所代表的数字写出来。

答案写在“解答.txt”中,不要写在这里

解法一思路:将一个五位数逆序之后和原数字再进行 “原数字 * 一个数 = 逆序数 ”的运算,在逆序过程中,为了保证每个数字都不同,故意将有相同数字的五位数的逆序数变成0,使得判断条件不满足而无法输出。同时为了实现逆序,自己写了一个pow函数

*

总体来说:

  1. 自我感觉自己的代码很笨重,很多多余的东西
  2. 有种被题目牵着鼻子走的感觉,只是读懂表面,然后完全按照题目表面意思实现,没有去分析它的本质,导致计算好复杂,循环次数也很多
  3. 自我批评自我告诫,也提醒可能会有同样问题的你

*

//我自己的解法
#include<iostream>
using namespace std;

int pow( int x,int n)
{
    int y = x;
    if( n == 0)
        return 1;   //满足一个数的零次幂为1
    for(int i = 0; i < n - 1; i++)
        x *= y;
    return x;
}

int Reverse(int x,int sum )
{
    sum = 0;
    int a[6];
    for(int i = 4; i >= 0; i--) {
        int n;
        a[i] = x % 10;
        x /= 10;
        for(int j = 4; j > i; j--)  //判断是否有重复
            if(a[i] == a[j])
                return 0;           //故意将有重复数字的逆序数变成0

        sum += a[i] * pow(10,i);

    }

    return sum;
}

int main(void)
{
    int x,sum;

    for( int x = 10000; x <= 99999; x++)
        // i 从2 开始,因为 1 的话只有5个数关于中间那个数对称的才会满足条件,所以1 是没有意义的
        for( int i = 2; i <= 9; i++)    
            if( x * i == Reverse(x,sum) )
                cout << x  << endl;

    return 0;
}

解法二思路:这个思路很清晰,就是将A,B,C,D,E按照单纯的数字来看,然后在每一层循环后嵌套一个判断条件,从而能够相对的减少循环次数,最后将数字合并,然后判断。
*
简单好理解,虽说没有什么算法可言,起码可以很快的实现,适合像我一样的小白啊哈

  • *
//解法二:网上参考的解法,自己实现的,感觉思路更清晰
#include<iostream>
using namespace std;

int main(void)
{
    for( int i = 1; i < 10; i++)
        for( int j = 0; j < 10; j++) {
            if( i == j)
                continue;
            for( int k = 0; k < 10; k++) {
                if( j == k || k == i)
                    continue;
                for( int l = 0; l < 10; l++) {
                    if( l == k || k == i || k == j)
                        continue;
                    for( int m = 0; m < 10; m++) {
                        if( m == l || m == k || m == j || m == i)
                            continue;
                        int n = i*10000 + j*1000 + k*100 + l*10 + m;
                        int p = m*10000 + l*1000 + k*100 + j*10 + i;
                        for( int q = 2; q < 10; q++)
                            if( n * q == p )
                                cout << n << endl;
                    }
                }
            }
        }

    return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值