首页 > 其他分享 >A Bit More Common (2024牛客多校1 B)

A Bit More Common (2024牛客多校1 B)

时间:2024-07-21 19:01:21浏览次数:18  
标签:特殊 int 数为 多校 2024 牛客 maxn res 序列

进入博客阅读体验更佳:A Bit More Common (2024牛客多校1 B) | 付诺の小站 (funuo0728.github.io)

A Bit More Common

题目大意


给定两个整数n和m(1 \le n,m \le 5000),在所有长度为n且元素取值范围为[0, 2 ^ m)的序列中,计算存在两个合法子序列的序列个数。其中,合法子序列是指子序列中所有元素按位与的结果为1。

由于答案可能很大,请将其对q(1 \le q \le 10^9)取模。

解题思路


首先考虑至少存在一个合法子序列的序列个数,对于合法子序列中的元素,第0位必须全为1,其余位上至少有一个0,对于剩下的其他元素,第0位必须全为0,其余位任选。我们对序列长度进行枚举,最终得到:

\sum_{i = 1}^{n}C_{n}^{i}(2 ^ {i} - 1)^{m - 1}2^{(m - 1)(n-i)} ①

题目要求我们求至少存在两个合法子序列的序列个数,那么接下来只需要求恰好只有一个合法子序列的情况,最后用至少1个的方案数减去恰好1个的方案数即为所求结果。

考虑这样一种按位与为1的子序列,去掉其中任何一个元素,他们的按位与都会变得不为1。首先这些元素的第0位上肯定都为1,自然想到如果某一个数在某一位上为0,而其余数在这一位上都为1,那么这个数就是不可或缺的。姑且将这种有且只有一个数在这一位上为0的位称为特殊位,只要每一个数都至少对应一位特殊位,这样得到的子序列就是要求的子序列。

考虑二维dp,f[i][j]表示总共有i个数,j位特殊位,每个数至少对应一个特殊位的方案数。

对于f[i][j]来说,每加入一位特殊位,可以使i个数字中的其中一个对应它,共有i种情况;也可以新增一个数字来对应它,然后发现从f[i][j]到f[i +1][j + 1]难以确定转移方程,于是思考从f[i + 1][j + 1]到f[i][j],发现去掉一个特殊位并使数减少的情况共有i + 1种,最终可得转移方程:

f[i][j] = i\cdot f[i][j - 1] + i\cdot f[i - 1][j - 1]

那么恰好存在一个合法子序列的思考方式与至少存在一个类似:

首先确定子序列的长度i,取长度为i的子序列的方案数为C_{n}^{i},

第0位全部为1,每个数至少对应1个特殊位,那么现在确定特殊位的个数j,至少为i,至多为m - 1,取j个特殊位的方案数为C_{m -1}^{j},

这i个数对应j个特殊位的方案数位f[i][j],

对于除去第0位和特殊位的其他位,每一位的总方案数为2 ^ i,减去全为1的情况为2 ^ i -1,再减去使这一位成为特殊位的情况2 ^ i - i - 1,最后这样的位有m - 1 - j个,那么方案数为(2^i - i - 1) ^ {m-1-j},

最后考虑其余数字,对于这些数字来说,除了第0位,其余位任填,方案数位2 ^ {(m - 1)(n-i)},

最终方案数为:

\sum_{i = 1}^{n}2^{(m - 1)(n - i)}C_n^i\cdot\sum_{j=i}^{m-1}C_{m-1}^jf[i][j](2^i - i - 1) ^ {m-1-j} ②

最后用①式减去②式即可。

参考代码

#include <bits/stdc++.h>
#define maxn 5010
#define int long long
using namespace std;
const double eps = 1e-8;
typedef long long ll;
typedef __int128_t i128;
i128 _base=1;
​
int n, m, mod, res = 0;
int C[maxn][maxn], f[maxn][maxn], pow2[maxn], tt[maxn];
​
inline ll mol(ll x){return x-mod*(_base*x>>64);}
​
int qmi(int a, int b, int m) {
    int res = 1;  a = mol(a);
    while(b) {
        if(b & 1)  res = mol(res * a);
        a = mol(a * a);
        b >>= 1;
    }
    return res;
}
​
void solve() {
    cin >> n >> m >> mod;
​
    _base=(_base<<64)/mod;
​
    pow2[0] = 1;
    for (int i = 1; i <= n; ++i)  pow2[i] = pow2[i - 1] * 2 % mod;
    for (int i = 1; i <= n; ++i)  tt[i] = qmi(2, (m - 1) * (n - i), mod);
 
    for (int i = 0; i <= 5000; ++i) {
        for (int j = 0; j <= i; ++j) {
            if(j == 0)  C[i][j] = 1;
            else  C[i][j] = (C[i - 1][j - 1] + C[i - 1][j]) % mod;
        }
    }
 
    for (int i = 1; i <= n; ++i) {
        for (int j = i; j <= m - 1; ++j) {
            if(i == 1)  f[i][j] = 1;
            else  f[i][j] = i * (f[i][j - 1] + f[i - 1][j - 1]) % mod;
        }
    }
 
    for (int i = 1; i <= n; ++i) {
        int t1 = C[n][i] * qmi((pow2[i] + mod - 1) % mod, m - 1, mod) % mod * tt[i] % mod;
        res = (res + t1) % mod;
    }
 
    res = ((res - C[n][1] * qmi(2, (n - 1) * (m - 1), mod) % mod) % mod + mod) % mod;
 
    for (int i = 2; i <= n; ++i) {
        for (int j = i; j <= m - 1; ++j) {
            int t1 = C[n][i] * tt[i] % mod;
            int t2 = C[m - 1][j] * f[i][j] % mod * qmi(((pow2[i] - i - 1) % mod + mod) % mod, m - 1 - j, mod) % mod;
            res = ((res - (t1 * t2 % mod)) % mod + mod) % mod;
        }
    }
​
    cout << res << '\n';
}
signed main() {
    ios::sync_with_stdio(false);
    cin.tie(0);  cout.tie(0);
    int t = 1;
    while (t--) {
        solve();
    }
    return 0;
}

标签:特殊,int,数为,多校,2024,牛客,maxn,res,序列
From: https://blog.csdn.net/jushdi/article/details/140591247

相关文章

  • SMU 2024 ptlks的周报Week 9 (7.15-7.21)
    这周学了启发式合并,prim算法,对图有了进一步的理解。树题意:给一棵根为1的有根树,点i具有一个权值\(A_i\)定义一个点对的值f(u,v)=max(\(A_u\),\(A_v\))×∣\(A_u\)-\(A_v\)∣。你需要对于每个节点i,计算\(ans_i=\displaystyle\sum_{u,v∈subtree(i)}f(u,v)\),其中subtre......
  • 2024牛客多校1
    2024牛客多校12024年第一场多校赛,打的很一般,多校之前vp的几场多校成绩还不错,一场比赛直接打回原形。赛时队友做的签到题C、H,吃了两发罚时,我自己推的A,出的很快,可惜没注意取模,吃了发罚时,长个记性吧。A给定n,m,p,问长度为n,并且都由小于\(2^m\)的数组成,存在一个子序列的按位且等......
  • NOI 2024
    省流:100+264+180=544,rk45极限进队。赛前状态感觉还行,gzy天天在模拟赛里爆标,给他磕头了。day0开幕式。很想喷【】【】【】【】【】【】,算了不喷了。笔试,开场10s大家就开始笑,笔试把答案发下来了。”我们题目的配置出了一点问题,大家稍安勿躁“。致敬传奇出题人。推迟15......
  • 2024大模型安全实践白皮书(可下载)
    以上是资料简介和目录,如需下载,请前往星球获取:https://t.zsxq.com/qd9rs......
  • vue3 ts 项目增加eslint插件实现命令行报错提示和vscode 报错提示,eslint 最新版本9.x
    快速开始安装eslintyarnaddeslint-D然后运行初始化eslintnpxeslint--init接着上面命令会自动生成一个新文件eslint.config.jseslint.config.jsimportglobalsfrom"globals";importpluginJsfrom"@eslint/js";importtseslintfrom"typescript-eslint......
  • 2024.7.20
    模拟赛昨天的题解还在咕。。。今天的又来了。。。T1SimpleMath2签到题,推一推式子就好了。\[\lfloor{\frac{a^b}{c}}\rfloor\modc=x\]\[\lfloor{\frac{a^b}{c}}\rfloor=k\timesc+x\]\[\frac{a^b-(a^b\modc)}{c}=k\timesc+x\]\[a^b-(a^b\modc)=k......
  • 免费【2024】springboot宝鸡文理学院学生成绩动态追踪系统
     博主介绍:✌CSDN新星计划导师、Java领域优质创作者、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流✌技术范围:SpringBoot、Vue、SSM、HTML、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大......
  • 免费【2024】springboot宝鸡文理学院学生成绩动态追踪系统
     博主介绍:✌CSDN新星计划导师、Java领域优质创作者、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流✌技术范围:SpringBoot、Vue、SSM、HTML、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大......
  • 免费【2024】springboot宝鸡文理学院学生成绩动态追踪系统
     博主介绍:✌CSDN新星计划导师、Java领域优质创作者、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流✌技术范围:SpringBoot、Vue、SSM、HTML、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大......
  • 2024夏令营提高1模考0721模拟赛(提高1)补题报告
    2024夏令营提高1模考0721模拟赛(提高1)补题报告\[07121模拟赛(提高1)\\\补题报告\\\\2024年7月21日\\\by\\\唐一潇\]一、做题情况第一题比赛\(100/100\),赛后通过第二题比赛\(0/100\),赛后通过第三题比赛\(0/100\),赛后通过第四题比赛\(0/100\)......