鱼C论坛

 找回密码
 立即注册
查看: 863|回复: 7

[已解决]求一个最小的数问题

[复制链接]
发表于 2022-2-24 19:30:16 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
题目如下 , 这是我写的代码 , 但是编译之后超时 , 不知道怎么回事

#include <bits/stdc++.h>
using namespace std;

int main(){
    int i = 17, j;
    int k = 0;
    bool isfind = 0;
    while(!isfind){
        j = i;
        while(j){
            j /= 10;
            k++;
        }
        if(i/10 + (int)pow(10, k-1)*7 == i * 5){
            isfind = 1;
            printf("%d", i);
        }
        i += 10;
    }
    return 0;
}
最佳答案
2022-2-24 22:53:49
本帖最后由 傻眼貓咪 于 2022-2-24 23:01 编辑

题意很简单,如果说这都会超时,必然不能以普通方法一个个寻找,肯定超时(这才是题目真正用意)

思路,比如三个数字:
abc(c 必然是 7)
cab 将 7 移到最左位

这里有个数学小知识,可以大大降低循环次数:
知识一:已知 cab 是 abc 的 5 倍,也就是说 b 是 c 的 5 倍数的个位数(7 的 5 倍数是 35,个位数是 5,所以 b 一定只能是 5)
知识二:已知 cab 是 abc 的 5 倍,也就是说 c >= a*5(如果说 c = 7,那么 a = 1 或 0,这里 0 被淘汰,因为首位数不能是 0,所以 a 必然就是 1)

注:运用以上两点,加上题目设定条件,便可知道 3 位数以内并没有答案,可以直接略过三位数,第一个数字必定是 1,最后第二个数字必定是 5,最后一个数字必定是 7,形成 1 xxxxxxxxx 57,每次循环 +100 便很快找到答案。

#include <iostream>
#include <cmath>

int A(int num){
    int res = 0;
    while(num /= 10) if(num) res ++;
    return res;
}

auto B = [](int num) -> int { return num/10 + 7*(static_cast<int>(pow(10, A(num)))); };

int main()
{
    int num = 1057;
    while(B(num) != num*5) num += 100;
    std::cout << num;
    return 0;
}
屏幕截图 2022-02-24 192833.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-2-24 20:24:28 | 显示全部楼层
本帖最后由 jhq999 于 2022-2-24 20:50 编辑
#include <math.h>
int main(){
    int i = 0, j;
    int k = 0;
    bool isfind = 0;
    while(!isfind){
        j = i;
        k=0;//////////////////
        while(j){
            j /= 10;
            k++;
        }
        if((i/10 + (int)pow(10.0, k-1)*7) == i * 5){
            isfind = 1;
            printf("%d", i);
            break;//////////////

        }
        i += 1;////////////
    }
    return 0;
}
142857
int main()
{
        int a=0,b=0,i=0,s=0;
                for (i = 1;; i++)
                {
                        a=i,s=1;
                        while(a)a/=10,s*=10;
                        a=i*100+57,b=(7*s+i)*10+5;
                        if (b%a==0)if(5==b/a)break;
                       // if (i*10/s==2)i=s;
                        
                
                }
               
                printf("%d %d",a,b);
                return 0;
142857 714285

评分

参与人数 1荣誉 +5 鱼币 +5 收起 理由
柿子饼同学 + 5 + 5

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-2-24 20:40:53 | 显示全部楼层
循环体中没有将 k 的值重置
#include <bits/stdc++.h>
using namespace std;

int main(){
    int i = 17, j;
    int k = 0;
    bool isfind = 0;
    while(!isfind){
        j = i;
        while(j){
            j /= 10;
            k++;
        }
        if(i/10 + (int)pow(10, k-1)*7 == i * 5){
            isfind = 1;
            printf("%d", i);
        }
        i += 10;
        k = 0; //将 k 的值重置
    }
    return 0;
}

评分

参与人数 1荣誉 +5 鱼币 +5 收起 理由
柿子饼同学 + 5 + 5

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-2-24 21:14:35 | 显示全部楼层
#include <stdio.h>
#include <math.h>

int main(){
    int number = 7, other, len, tmp, newNumber;

    while(number+=10){
        // 取长度
        len = 1;
        tmp = number;
        while(tmp/=10){
            len++;
        };

        other = number / 10; // 取其它位
        newNumber = 7*(int)pow(10, len-1) + other; // 移位后的数
        if(number*5==newNumber){
            printf("%d\n", number);
            break;
        }
    }

    return 0;
}

评分

参与人数 1荣誉 +5 鱼币 +5 收起 理由
柿子饼同学 + 5 + 5

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2022-2-24 22:53:49 | 显示全部楼层    本楼为最佳答案   
本帖最后由 傻眼貓咪 于 2022-2-24 23:01 编辑

题意很简单,如果说这都会超时,必然不能以普通方法一个个寻找,肯定超时(这才是题目真正用意)

思路,比如三个数字:
abc(c 必然是 7)
cab 将 7 移到最左位

这里有个数学小知识,可以大大降低循环次数:
知识一:已知 cab 是 abc 的 5 倍,也就是说 b 是 c 的 5 倍数的个位数(7 的 5 倍数是 35,个位数是 5,所以 b 一定只能是 5)
知识二:已知 cab 是 abc 的 5 倍,也就是说 c >= a*5(如果说 c = 7,那么 a = 1 或 0,这里 0 被淘汰,因为首位数不能是 0,所以 a 必然就是 1)

注:运用以上两点,加上题目设定条件,便可知道 3 位数以内并没有答案,可以直接略过三位数,第一个数字必定是 1,最后第二个数字必定是 5,最后一个数字必定是 7,形成 1 xxxxxxxxx 57,每次循环 +100 便很快找到答案。

#include <iostream>
#include <cmath>

int A(int num){
    int res = 0;
    while(num /= 10) if(num) res ++;
    return res;
}

auto B = [](int num) -> int { return num/10 + 7*(static_cast<int>(pow(10, A(num)))); };

int main()
{
    int num = 1057;
    while(B(num) != num*5) num += 100;
    std::cout << num;
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-2-24 22:57:11 | 显示全部楼层
c_cpp_python 发表于 2022-2-24 20:40
循环体中没有将 k 的值重置

哇哇哇 , 我刚刚改了居然真的过了 , 谢谢~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-2-24 23:02:59 | 显示全部楼层
傻眼貓咪 发表于 2022-2-24 22:53
题意很简单,如果说这都会超时,必然不能以普通方法一个个寻找,肯定超时(这才是题目真正用意)

思路, ...

哇 , 思路好清晰
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-2-24 23:08:36 | 显示全部楼层

谢谢你
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-18 11:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表