码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • CodeTON Round 3 (Div. 1 + Div. 2, Rated, Prizes) 「D. Count GCD gcd+容斥」


    D. Count GCD

    题目描述:

    给你一个长度为n的数组a[i],你需要构造一个长度为n的数组b[i],对于1<=i<=n,要满足a[i] = gcd(b[1], b[2]...,b[i]), 1<=b[i]<=m,问存在多少种不同的方法,对998244353取模

    思路:

    分析一下,对于每个i,必须满足a[i]%a[i-1]=0,否则答案就是0

    对于b[i],由于a[i-1]=gcd(b[1],b[2],...,b[i-1])我们其实只需要满足gcd(a[i-1], b[i])=a[i]即可我们假设a[i-1] = k*a[i],b[i]=a[i]*p,则我们只需要满足gcd(k,p) = 1即可,所以我们只需要知道 1 − m a [ i ] 1-\frac{m}{a[i]} 1−a[i]m​中与 a [ i − 1 ] a [ i ] \frac{a[i-1]}{a[i]} a[i]a[i−1]​互质的数字的数量就行

    这就是一个容斥的板子,先质因数分解以后,再二进制枚举子集进行容斥

    #include 
    using namespace std;
    
    #define endl '\n'
    #define inf 0x3f3f3f3f
    #define mod7 1000000007
    #define mod9 998244353
    #define m_p(a,b) make_pair(a, b)
    #define mem(a,b) memset((a),(b),sizeof(a))
    #define io ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
    typedef long long ll;
    typedef pair <int,int> pii;
    #define int long long
    #define MAX 300000 + 50
    int n, m, k, x;
    int tr[MAX];
    
    vector<ll> pme;
    ll count_prime(ll n,ll x){
        pme.clear();
        for(ll i=2;i<=sqrt(x);++i){
            if(x%i==0){
                pme.push_back(i);
                while(x%i==0) x/=i;
            }
        }
        if(x>1) pme.push_back(x);
        ll sum=0;
        for(int i=1;i<(1<<pme.size());++i){
            ll z=1,num=0;
            for(int j=0;j<pme.size();++j)
                if(i>>j&1) {z*=pme[j];++num;}
            if(num&1) sum+=n/z;
            else sum-=n/z;
        }
        return n-sum;
    }
    
    
    void work(){
        cin >> n >> m;
        for(int i = 1; i <= n; ++i){
            cin >> tr[i];
        }
        ll ans = 1;
        for(int i = 2; i <= n; ++i){
            if(tr[i-1] % tr[i] != 0){
                cout << 0 << endl;
                return;
            }
            (ans *= count_prime(m/tr[i], tr[i-1]/tr[i]))%=mod9;
        }
        cout << ans << endl;
    }
    
    
    signed main(){
        io;
        int t;cin>>t;while(t--)
        work();
        return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62

    (擦线水到两个ton币,好耶

  • 相关阅读:
    代码随想录48——动态规划:198打家劫舍、213打家劫舍II、337打家劫舍III
    哪里有写毕业论文需要的外文文献?
    PAT 甲级 A1018 Public Bike Management
    概率论的学习和整理--番外11:10球里8红球2白球,抽俩次抽中白球的概率是多少呢? 一个例题的不同方法
    MySQL高级(二)
    手机运行内存大揭秘:探索你手机的超级大脑!
    angr原理与实践(一)——原理
    开源游戏引擎和模拟器的项目合集 | 开源专题 No.38
    【git】【IDEA】在idea中使用git
    Office在线协作(三)- O2OA连接本地部署的OnlyOffice Docs Server服务器 For Windows Server
  • 原文地址:https://blog.csdn.net/weixin_51216553/article/details/127736477
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号