码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • LQ0019 数的拆分【素数】


    题目来源:蓝桥杯2022初赛 C++ A组I题,C++ G组I题

    题目描述
    给定T个正整数a,分别问每个ai能否表示为x1y1·x2y2的形式。
    其中x1、x2为正整数,y1、y2为大于等于2的正整数。

    输入格式
    输入第一行包含一个整数T,表示询问次数。
    接下来T行,每行一个正整数ai。
    10% 的评测用例,1 ≤ T ≤ 200,ai ≤ 10^9;
    30% 的评测用例,1 ≤ T ≤ 300,ai ≤ 10^18;
    60% 的评测用例,1 ≤ T ≤ 10000,ai ≤ 10^18;
    100%的评测用例,1≤ T ≤ 100000,1 ≤ ai ≤ 10^18。

    输出格式
    对于每次询问, 如果ai 能够表示为题目描述的形式则输出yes,否则输出no。

    输入样例
    7
    2
    6
    12
    4
    8
    24
    72

    输出样例
    no
    no
    no
    yes
    yes
    no
    yes

    问题分析
    暴力分解的方法必定会超时,参加程序代码。
    有关题解原理参见参考链接。

    参考链接:2022年蓝桥杯省赛 C/C++ A组题解

    AC的C语言程序如下:

    /* LQ0019 数的拆分 */
    
    #include 
    #include 
    #include 
    #include 
    
    using namespace std;
    
    // Eratosthenes筛选法
    const int N = 4000;
    bool isprime[N + 1];
    int prime[N / 3], pcnt = 0;
    void esieve(void)
    {
        memset(isprime, true, sizeof isprime);
        prime[pcnt++] = 2;
        for (int i = 3; i <= N; i += 2)
            if (isprime[i]) {
                prime[pcnt++] = i;
                for (int j = i + i; j <= N; j += i)
                    isprime[j] = false;
            }
    }
    
    typedef long long LL;
    
    bool judge(LL n)
    {
        LL t = sqrt(n);
        if (t * t == n) return true;
        t = cbrt(n);
        if (t * t * t == n) return true;
        return false;
    }
    
    int main()
    {
        esieve();
    
        int t;
        LL a;
        scanf("%d", &t);
        while (t--) {
            scanf("%lld", &a);
    
            if (judge(a))
                puts("yes");
            else {
                bool flag = true;
                for (int i = 0; i < pcnt; i++) {
                    int cnt = 0;
                    if (a % prime[i] == 0)
                        while (a % prime[i] == 0)
                            cnt++, a /= prime[i];
                    if (cnt == 1) {
                        flag = false;
                        break;
                    }
                }
                puts(flag && judge(a) ? "yes" : "no");
            }
        }
    
        return 0;
    }
    

    超时的C语言程序(暴力)如下:

    /* LQ0019 数的拆分 */
    
    #include 
    
    int judge(long long n)
    {
        for (long long i = 2; i * i <= n; i++) {
            if (n % i == 0) {
                int cnt1 = 0;
                while (n % i == 0)
                    cnt1++, n /= i;
                if (n == 1) {
                    // n可以写成i^cnt1*1^2,则返回1
                    if (cnt1 >= 2) return 1;
                } else {
                    for (long long j = i + 1; j * j <= n; j++)
                        if (n % j == 0) {
                            int cnt2 = 0;
                            while (n % j == 0)
                                cnt2++, n /= j;
                            if (n == 1) {
                                // n可以写成i^cnt1*j^cnt2,则返回1
                                if (cnt2 >= 2) return 1;
                            }
                        }
                }
            }
        }
        return 0;
    }
    
    int main()
    {
        int t;
        long long a;
        scanf("%d", &t);
        while (t--) {
            scanf("%lld", &a);
    
            printf("%s\n", judge(a) ? "yes" : "no");
        }
    
        return 0;
    }
    
  • 相关阅读:
    Android 四大组件 -- service
    程序员转行短视频的故事(一)
    【会议征稿通知】第三届密码学、网络安全和通信技术国际会议(CNSCT 2024)
    帝国cms如何隐藏指定信息不在列表页显示
    「实用场景教程」如何用日程控件DHTMLX Scheduler制作酒店预订日历?(一)
    Java开发学习---Maven私服(二)本地仓库访问私服配置与私服资源上传下载
    Metasploit——客户端渗透
    Containerd容器运行时的Kubernetes(K8s)环境搭建
    17. Spring类型转换之PropertyEditor
    字符串笔记-字符串哈希
  • 原文地址:https://blog.csdn.net/tigerisland45/article/details/126962891
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号