• 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]} 1a[i]m中与 a [ i − 1 ] a [ i ] \frac{a[i-1]}{a[i]} a[i]a[i1]互质的数字的数量就行

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

    #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币,好耶

  • 相关阅读:
    CMake教程-第 5 步:安装和测试
    Vue2数据双向绑定的原理(Object.defineProperty)
    风雨秋招路-CV太难了-记得复盘
    RabbitMQ:路由模式
    [SpringMVC笔记] SpringMVC-14-SSM整合-异常处理器
    Java序列化有什么作用
    程序员如何运营好博客平台
    如何低成本的玩转独立站
    基于springboot网上书城系统
    Layui快速入门之第一节Layui的基本使用
  • 原文地址:https://blog.csdn.net/weixin_51216553/article/details/127736477