1 条题解

  • 0
    @ 2025-8-24 23:13:18

    自动搬运

    查看原文

    来自洛谷,原作者为

    avatar easy42
    无蓝钩不改签

    搬运于2025-08-24 23:13:18,当前版本为作者最后更新于2025-04-14 13:37:32,作者可能在搬运后再次修改,您可在原文处查看最新版

    自动搬运只会搬运当前题目点赞数最高的题解,您可前往洛谷题解查看更多

    以下是正文


    根据提示,要求的数就是含有至少 110022221155 的数。

    这时候直接数位分离即可,如下:

    int t=i;
    int a=0,b=0,c=0;
    while(t!=0){
        if(t%10==0) a++;
        if(t%10==2) b++;
        if(t%10==5) c++;
        t/=10;
    }
    if(a>=1&&b>=2&&c>=1) ans++;
    

    完整代码:

    #include<bits/stdc++.h>
    using namespace std;
    int main(){
        int ans=0;
        for(int i=1;i<=20250412;i++){
            int t=i;
            int a=0,b=0,c=0;
            while(t!=0){
                if(t%10==0) a++;
                if(t%10==2) b++;
                if(t%10==5) c++;
                t/=10;
            }
            if(a>=1&&b>=2&&c>=1) ans++;
        }
        cout<<ans;
        return 0;
    }
    
    • 1

    信息

    ID
    12013
    时间
    1000ms
    内存
    512MiB
    难度
    1
    标签
    递交数
    0
    已通过
    0
    上传者