ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

arc 116C - Multiple Sequences

2021-04-09 15:58:11  阅读:257  来源: 互联网

标签:Multiple int res ll arc Sequences inv dp mod


传送门

题意:给定n(2e5),m(2e5),求长度为n序列A的个数,其中A_{i + 1}A{i}的整数倍,且A{i}不超过m

dp[n][m]表示最后一个元素为n,长度为m,元素互不相同,每个元素是前一个元素的整数倍(至少2倍)的序列个数,易知序列长度不会超过19

元素可以重复的情况等价于在不可重复的情况下乘上用隔板法把n个相同小球放入j个不同盒子且盒子非空的方案数,在上面方案数乘上C_{n-1}^{j -1}即可

最终答案为\sum_{i=1}^{m}\sum_{j=1}^{19}dp[i][j] * C_{n - 1}^{j - 1}

#include<bits/stdc++.h>
using namespace std;
using ll = long long;
const int mod = 998244353;
const int maxn = 2e5 + 5;
ll dp[maxn][22];
ll fac[maxn], inv[maxn];
ll n, m;
ll qpow(ll x, ll y)
{
    ll res = 1;
    while(y)
    {
        if(y & 1) res = res * x % mod;
        x = x * x % mod;
        y >>= 1;
    }
    return res;
}
void init()
{
    fac[0] = 1;
    for(int i = 1; i <= 200000; ++i) fac[i] = i * fac[i - 1] % mod;
    inv[200000] = qpow(fac[200000], mod - 2);
    for(int i = 200000 - 1; i >= 0; --i) inv[i] = inv[i + 1] * (i + 1) % mod;
}
ll C(ll n, ll m)
{
    if(n < m) return 0;
    return fac[n] * inv[m] % mod * inv[n - m] % mod; 
}
int main() 
{
	cin >> n >> m;
    init();
    for(int i = 1; i <= m; ++i) dp[i][1] = 1;
    for(int i = 1; i <= 19; ++i)
    {
        for(int j = 1; j <= m; ++j)
        {
            for(int k = 2; k <= m; ++k)
            {
                if(j * k > m) break;
                dp[j * k][i + 1] = (dp[j * k][i + 1] + dp[j][i]) % mod;
            }
        }
    }
    ll ans = 0;
    for(int i = 1; i <= m; ++i)
    {
        for(int j = 1; j <= 19; ++j)
        {
            ans = (ans + dp[i][j] * C(n - 1, j - 1) % mod) % mod;
        }
    }
    cout << ans << endl;
}

 

标签:Multiple,int,res,ll,arc,Sequences,inv,dp,mod
来源: https://blog.csdn.net/qq_37765455/article/details/115551775

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有