E. MEXimize the Score

news/2024/11/17 14:41:28/文章来源:https://www.cnblogs.com/lyrrr/p/18550530

首先观察到性质是贡献肯定是cnt[0]+min(cnt[0],cnt[1])+min(cnt[0],cnt[1],cnt[2])....这样的
设状态为f[i][j],表示在选到数i时有j个数i产生了贡献的方法数
转移分为两种情况,一种是数i的数量限制,一种是f[i-1][j]限制(分类非常重要
那么f[i][j]对ans的贡献是包含这种选法的子序列数量,就相当于把序列前一部分选好了,后面任取,所以是
(j是该方案贡献的分数)
\(f[i][j]\times 2^{(i+1)+...+(n-1)}\times j\)

总结一下这题分为三个步骤,第一步观察,第二步把贡献拆分成两部分去求,先dp求出f[i][j]的贡献,再求子序列种类贡献,分类非常重要
然后用vector写这种题很容易越界,要判断好

#include <bits/stdc++.h>
using namespace std;
#define lowbit(x) (x & (-x))
#define pii pair<int, int>
#define mkp make_pair
#define LL long long
#define int long long
#define endl '\n'const int N = 2e5 + 10, mod = 998244353;int n, cnt[N], pinv[N], pre[N], fcnt[N];int qpow(int x, int y)
{int res = 1;while (y){if (y & 1)res = 1ll * x * res % mod;x = 1ll * x * x % mod;y >>= 1;}return res;
}
int inv(int x)
{return qpow(x, mod - 2);
}
int C(int x, int y)
{if(y < x || x < 0) return 0;return 1ll * pre[y] * pinv[x] % mod * pinv[y - x] % mod;
}
int add(int x, int y)
{return (x + y >= mod) ? (x + y - mod) : (x + y);
}
int sub(int x, int y)
{return (x - y < 0) ? (x - y + mod) : (x - y);
}
int mul(int x, int y)
{return 1ll * x * y % mod;
}
void solve()
{cin >> n;vector<int> f(n + 10, 0);for (int i = 1; i <= n; i++){int x;cin >> x;cnt[x]++;}fcnt[n + 1] = fcnt[n] = 0;for (int i = n - 1; i >= 1; i--)fcnt[i] = fcnt[i + 1] + cnt[i];LL ans = 0;for (int i = 1; i <= cnt[0]; i++){f[i] = C(i, cnt[0]);ans = add(ans, mul(f[i], mul(i, qpow(2, fcnt[1]))));}for (int i = 1; i < n; i++){vector<int> fx(cnt[i] + 5, 0);vector<int> suf(cnt[i] + 5, 0);vector<int> fsuf(cnt[i - 1] + 5, 0);for (int j = cnt[i]; j >= 0; j--)suf[j] = add(suf[j + 1], C(j, cnt[i]));for (int j = cnt[i - 1]; j >= 1; j--)fsuf[j] = add(fsuf[j + 1], f[j]);for (int j = 1; j <= cnt[i]; j++){if(j <= cnt[i - 1]) fx[j] = mul(f[j], suf[j]);if(j + 1 <= cnt[i - 1]) fx[j] = add (fx[j], mul(fsuf[j + 1], C(j, cnt[i])));ans = add(ans, mul(fx[j], mul(j, qpow(2, fcnt[i + 1]))));// cout << suf[j] << ' ' << mul(fsuf[j + 1], C(j, cnt[i])) << ' ' << fx[j] << ' ' << endl;}// cout << i <<endl;swap(fx, f);}cout << ans << endl;// clearfor (int i = 0; i <= n; i++)cnt[i] = 0;
}signed main()
{ios::sync_with_stdio(false);cin.tie(nullptr);pre[0] = pinv[0] = 1;for (int i = 1; i <= N - 5; i++)pre[i] = 1ll * pre[i - 1] * i % mod;pinv[N - 6] = inv(pre[N - 6]);for (int i = N - 7; i >= 0; i--)pinv[i] = 1ll * pinv[i + 1] * (i + 1) % mod;// cout<<pinv[2]*2%mod<<endl;int T = 1;cin >> T;while (T--)solve();
}
/*
4
3
0 0 1
4
0 0 1 1
5
0 0 1 2 2
4
1 1 1 1
*/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/835329.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学期2024-2025-1 学号20241421 《计算机基础与程序设计》第8周学习总结

作业信息 |这个作业属于哪个课程|https://edu.cnblogs.com/campus/besti/2024-2025-1-CFAP| |这个作业要求在哪里|https://www.cnblogs.com/rocedu/p/9577842.html#WEEK08| |这个作业的目标|功能设计与面向对象设计,面向对象设计过程,面向对象语言三要素,汇编、编译、解释、…

QObject,QMainWindpw,QWidget,QDialog介绍

QObject QObject 的角色和特点 在 Qt 框架中,QObject 是整个对象模型的核心基类,它为 Qt 对象树 和 信号-槽机制 提供了基础支持。很多 Qt 的类(包括 QWidget、QDialog、QMainWindow)都直接或间接继承自 QObject。 QObject 的核心功能对象树管理(Object Tree)QObject 提供…

2024-2025-1 20241329 《计算机基础与程序设计》第八周学习总结

作业信息 作业归属课程:https://edu.cnblogs.com/campus/besti/2024-2025-1-CFAP 作业要求:https://www.cnblogs.com/rocedu/p/9577842.html#WEEK08 作业目标:功能设计与面向对象设计;面向对象设计过程;面向对象语言三要素;汇编、编译、解释、执行 作业正文:https://www…

Alpha冲刺(4/14)——2024.11.15

目录一、团队成员分工与进度二、成员任务问题及处理方式三、冲刺会议内容记录会议内容四、GitHub签入记录及项目运行截图GitHub签入记录五、项目开发进展及燃尽图项目开发进展燃尽图六、团队成员贡献表 一、团队成员分工与进度成员 完成的任务 完成的任务时长 剩余时间施靖杰 完…

高三鲜花 #2

水发现放假之后其实连鲜花都是不想写的了。 所以这是钓鱼博。 也不能钓这么直接,还是需要写一点东西的。 应该是马上就距离高考还剩 200 天了。然后这里本来写了很多关于 whk 的文本,全删了,觉得有点无意义,毕竟这应该是一篇钓鱼博。 whk 真难。 突然发现我已经退役四个月了…

语文成绩

语文成绩(https://www.luogu.com.cn/record/189365158) 题目描述 语文老师总是写错成绩,所以当她修改成绩的时候,总是累得不行。她总是要一遍遍地给某些同学增加分数,又要注意最低分是多少。你能帮帮她吗? 输入格式 第一行有两个整数 n,p,代表学生数与增加分数的次数。…

「LUCKY STUN穿透」使用Cloudflare的页面规则固定和隐藏网页端口

关于本教程 索引 │ ├─关于本教程 │ ├─在STUN穿透环境中使用WEB服务 │ ├─动态端口带来的麻烦 │ ├─“隐藏端口”和固定端口 │ └─可用的解决方法 │ ├─使用邮件进行通知端口变化 │ └─使用HTTP重定向 │ ├─网络环境优化和STUN穿透规则设…

平板电视食用教程

先来看一道大家基本都能默写出来的题目: 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:插入一个数 \(x\)。 删除一个数 \(x\)(若有多个相同的数,应只删除一个)。 定义排名为比当前数小的数的个数 \(+1\)。查询 \(x\) 的排名。 查询数据结…

企业集成模式-第十二章

十二、中场演练:系统管理示例管理控制台:显式所有组件的工作状态(下图一) 贷款中介的服务质量:监视请求响应时间 验证信用机构的操作:周期性地发送测试消息,希望确信该服务在正常运行(下图二) 信仰机构的故障恢复:如果信仰机构出现故障,希望把信用请求消息临时重定向…

平板电视从入门到精通

先来看一道大家基本都能默写出来的题目: 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:插入一个数 \(x\)。 删除一个数 \(x\)(若有多个相同的数,应只删除一个)。 定义排名为比当前数小的数的个数 \(+1\)。查询 \(x\) 的排名。 查询数据结…

人月神话-摘抄

由于人员的分工,大型编程项目碰到的管理问题和小项目区别很大:我相信关键需要是维持产品自身的概念完整性。 1. 焦油坑(the tar pit) 过去几十年的大型系统开发犹如这样一个焦油坑,很多大型和强壮的动物在其中剧烈地挣扎。他们中大多数开发出了可运行的系统-不过,其中只有非…

Manjaro/Arch用怎么安装天翼云电脑(Ctyun-cloud-desk)?感谢信创,感谢国家

最近微信出了linux版,用vmware装linux不过瘾,把一台闲置的笔记本装上了Manjaro KDE Plasma,经过一段时间的发展,Linux桌面可用性大大提高。 Kindle->Kindle Mate->Anki这条路在linux下 我用 Kindle ->KindleVocab ->Anki这么代替了之后, 其他软件都能凑合用,…