[十二省联考2019]皮配

题目链接

选一个派系和一个阵营可以唯一确定一名导师

因为每一个阵营里的导师都分别来自不同派系,所以k=0时,对阵营的选择是不影响对派系的选择的

唯一的限制就是同城市的要在同一个阵营

所以以每个城市为物品,物品大小为该城市的人数,阵营人数为背包容量,做背包dp

再以每个学校为物品,物品大小为该学校的人数,派系人数为背包容量,做背包dp

只用一维记录背包大小即可,因为总人数-背包里的人数=在另一个阵营或派系的人数

然后合并答案即可

方案数是可以相互乘起来的,k很小,所以我们可以暴力做k!=0的情况,然后乘上符合要求的k==0的方案数

k!=0时,记\(f[x][t][i][j]\)为前x个学校,前一个学校选择了t阵营,此时蓝有i个人,鸭派有j个人的方案数

滚动第一维,否则空间会爆

将学校按城市排序,这样相同城市的就会排在一起,转移的时候如果和前一个学校同城就要选择相同阵营

#include<bits/stdc++.h>
#define rep(i,j,k) for(int i=j;i<=k;++i)
using namespace std;
typedef long long ll;
typedef double db;
char cch;
inline int rd(){int x=0,fl=1;cch=getchar();while(cch>'9'||cch<'0'){if(cch=='-') fl=-1;cch=getchar();}while(cch>='0'&&cch<='9') x=(x<<3)+(x<<1)+cch-'0',cch=getchar();return x*fl;
}
const int mod=998244353,N=3000;
struct abc{int ct,sum,ban;
}p1[N],p2[N];
int f[N],g[N],ff[2][2][N][N],ok[N],bl[N],ct[N],city[N],sum[N],ban[N];
inline void inc(int &A,int B){//会比 %mod快一点点 A+=B;if(A>mod) A-=mod;if(A<0) A+=mod;
}
inline int mul(int A,int B){return 1ll*A*B%mod;
}
inline int sub(int a,int b){a-=b;if(a<0) a+=mod;return a;
}
inline int getg(int l,int r){if(l>r) return 0;if(l==0) return g[r];//为了dp方便g[0]=1,实际上应该是0return sub(g[r],g[l-1]);
}
inline int getf(int l,int r){if(l>r) return 0;if(l==0) return f[r];//同理 return sub(f[r],f[l-1]);
}
inline bool cmp(const abc &a1,const abc &a2){return a1.ct<a2.ct;
}
inline void sv(){int n=rd(),c=rd(),c0=rd(),c1=rd(),d0=rd(),d1=rd(),ans=0,tot=0;//n所学校,c个城市,蓝阵营 C0。 红阵营 C1。 鸭派系 D0。 R派系D1。memset(city,0,sizeof city);rep(i,1,n) ct[i]=rd(),sum[i]=rd(),tot+=sum[i],ban[i]=-1,city[ct[i]]+=sum[i];//city[i]表示第i个城市一共有多少人 int k=rd(),id;rep(i,1,k) id=rd(),ban[id]=rd();int len1=0,len2=0;rep(i,1,n){if(ban[i]!=-1) p1[++len1]=(abc){ct[i],sum[i],ban[i]};//有特殊要求的 else p2[++len2]=(abc){ct[i],sum[i],ban[i]};//没有特殊要求的 }sort(p1+1,p1+len1+1,cmp);//按城市排序rep(i,1,len1){if(city[p1[i].ct]==-1) ok[i]=0;//阵营的转移以城市为单位else ok[i]=city[p1[i].ct]/*注意*/,city[p1[i].ct]=-1;}//memset(g,0,sizeof g),g[0]=1;rep(i,1,c) if(city[i]>0) for(int j=c0;j>=city[i];--j) inc(g[j],g[j-city[i]]);/*做前缀和*/rep(i,1,c0) inc(g[i],g[i-1]);//memset(f,0,sizeof f),f[0]=1;rep(i,1,len2) for(int j=d0;j>=p2[i].sum;--j) inc(f[j],f[j-p2[i].sum]);/*做前缀和*/rep(i,1,d0) inc(f[i],f[i-1]);//memset(ff,0,sizeof ff);//ff[x][t][i][j]为前x个学校,前一个学校选择了t阵营,此时蓝有i个人,鸭派有j个人的方案数,滚动第一维 ff[0][0][0][0]=1;int cnt=0,now=0;rep(i,1,len1){//对有要求的学校暴力求解now^=1;int tmp=p1[i].sum,bn=p1[i].ban,d=ok[i],lst=cnt;//lst=之前的学校的总人数 cnt+=tmp;rep(t,0,1) rep(h,0,c0) rep(j,0,cnt) ff[now][t][h][j]=0;//这里不可以用memset,用了会超时,因为一开始cnt很小,所以循环更快 rep(t,0,1){int cs=-1;//choiseif(i>1&&p1[i].ct==p1[i-1].ct) cs=t; for(int i=c0;i>=0;--i) for(int j=cnt;j>=0;--j){if(cs!=1){//如果同城市的选择了0阵营,或与上一个不同城,if(bn!=1&&i>=d&&j<=lst) inc(ff[now][0][i][j],ff[now^1][t]/*注意是t而不是0*/[i-d][j]);//没有禁掉小R,可以加入R派 if(bn!=0&&i>=d&&j-tmp<=lst&&j>=tmp) inc(ff[now][0][i][j],ff[now^1][t][i-d][j-tmp]);//没有禁掉Yazid,可以加入鸭派}if(cs!=0){//如果同城市的选择了1阵营,或与上一个不同城,if(bn!=3&&j<=lst) inc(ff[now][1][i][j],ff[now^1][t][i][j]);if(bn!=2&&j-tmp<=lst&&j>=tmp) inc(ff[now][1][i][j],ff[now^1][t][i][j-tmp]);}}}}//rep(t,0,1) rep(i,0,c0) rep(j,0,d0){int v=ff[now][t][i][j];if(!v)continue;int t1=c0-i,t2=max(0,tot-d1-j),t3=max(0,tot-c1-i),t4=d0-j;//符合人数要求的区间 inc(ans,mul(v,mul(getg(t3,t1),getf(t2,t4))));}printf("%d\n",ans);
}
int main(){int T=rd();while(T--) sv();
}
/*
2
2 1
3 2 2 2
1 1
1 2
1
1 0
4 2
10 30 20 30
1 6
2 4
1 7
2 4
2
2 3
3 1
*/

转载于:https://www.cnblogs.com/Doingdong/p/10727364.html

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

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

相关文章

机器学习理论梳理1: PCA主成分分析

机器学习的理论部分学习知识点比较乱且杂。我这里通过几篇文章&#xff0c;简单总结一下自己对机器学习理论的理解&#xff0c;以防遗忘。第一篇文章主要概述了机器学习的基本任务以及一个常用的降维方法&#xff0c;主成分分析。 机器学习的基本任务 机器学习能实现许多不同…

29 _react-router说明

一、SPA的理解 1.单页面web应用(single page web application ,SPA) 2.整个应用只有一个完整的页面 3.点击页面中的链接不会刷新页面&#xff0c;本身也不会向服务器发请求 4.当点击路由链接时&#xff0c;只会做页面的局部更新 5.数据都需要通过ajax请求获取&#xff0c;并在前…

Java程序员如何快速理解Kubernetes

我们希望微服务是可复制的&#xff0c;可替换的工作节点&#xff0c;这样可以轻松进行升级或降级&#xff0c;同时无需任何停机时间&#xff0c;并花费最少代价的管理。我们可以说我们希望他们成为我们的小黄人&#xff08;minions&#xff09;。本文我们将通过一个简单的例子来…

NLP基础 : HMM 隐马尔可夫模型

Hidden Markov Model, HMM 隐马尔可夫模型&#xff0c;是一种描述隐性变量(状态)和显性变量(观测状态)之间关系的模型。该模型遵循两个假设&#xff0c;隐性状态i只取决于前一个隐性状态i-1&#xff0c;而与其他先前的隐形状态无关。观测状态也只取决于当前的隐形状态。因此我们…

关于秒杀系统优化方向

今天听了一节咕泡学院的公开课&#xff0c;有收获。 秒杀系统的特点&#xff1a; 1.限时&#xff1b;2.限量供应&#xff1b;3.并发量大&#xff1b;如何优化&#xff1a; 1.客户端数据缓存。 2.CDN加速。 3.nginx动静分离&#xff0c;静态资源缓存&#xff0c;负载均衡。 4.se…

Mysql插入很慢,找到了稍微快点的方法

MYSQL批量插入数据库实现语句性能分析 假定我们的表结构如下 代码如下 CREATE TABLE example ( example_id INT NOT NULL, name VARCHAR( 50 ) NOT NULL, value VARCHAR( 50 ) NOT NULL, other_value VARCHAR( 50 ) NOT NULL ) 通常情况下单条插入的sql语句我们会这么写&…

Linux - 时间相关命令 - ntpdate, date, hwclock

1. 概述 最近也不知道写啥了, 把之前的老文档整理一下, 凑个数什么的配置时间这种工作, 偶尔还是要用一下主要描述 3 个命令的简单适用 ntpdatehwlock2. ntpdate 1. 概述 用于同步时钟的命令2. 机制 通常是有一个服务器对外提供时间客户端可以与时间服务器同步ntp 是他们之间交…

RUNOOB python练习题1

用来练手的python 练习题&#xff0c;原链接 : python练习实例1 题干 : 有四个数字&#xff1a;1、2、3、4&#xff0c;能组成多少个互不相同且无重复数字的三位数&#xff1f;各是多少&#xff1f; import numpy as np cen np.array([1,2,3,4]) tens np.array([1,2,3,4])…

mysql explain用法和结果的含义

explain显示了mysql如何使用索引来处理select语句以及连接表。可以帮助选择更好的索引和写出更优化的查询语句。 使用方法&#xff0c;在select语句前加上explain就可以了&#xff1a; 如&#xff1a; explain select surname,first_name form a,b where a.idb.id EXPLAIN列…

日志模块logging用法

一、常用日志记录场景及最佳解决方案&#xff1a; 日志记录方式 最佳记录日志方案 普通情况下&#xff0c;在控制台显示输出 print() 报告正常程序操作过程中发生的事件 logging.info()(或者更详细的logging.debug()) 发出有关特定事件的警告 warnings.warn()或者loggin…

MySQL 亿级数据需求的优化思路(一),交易流水记录的查询

对MySQL的性能和亿级数据的处理方法思考&#xff0c;以及分库分表到底该如何做&#xff0c;在什么场景比较合适&#xff1f; 比如银行交易流水记录的查询 限盐少许&#xff0c;上实际实验过程&#xff0c;以下是在实验的过程中做一些操作&#xff0c;以及踩过的一些坑&#…

RUNOOB python练习题2

用来练手的python 练习题&#xff0c;原链接 : python练习实例2 题干 : 企业发放的奖金根据利润提成。利润(I)低于或等于10万元时&#xff0c;奖金可提10%&#xff1b;利润高于10万元&#xff0c;低于20万元时&#xff0c;低于10万元的部分按10%提成&#xff0c;高于10万元的…

dubbo负载均衡策略和集群容错策略

dubbo负载均衡策略 random loadbalance 默认情况下&#xff0c;dubbo是random load balance随机调用实现负载均衡&#xff0c;可以对provider不同实例设置不同的权重&#xff0c;会按照权重来负载均衡&#xff0c;权重越大分配流量越高&#xff0c;一般就用这个默认的就可以了。…

MySQL 亿级数据需求的优化思路(二),100亿数据,1万字段属性的秒级检索

最近在研究亿级数据的时候&#xff0c;无意中看到了一个关于写58同城的文章 https://blog.csdn.net/admin1973/article/details/55251499?fromtimeline 其实上面讲的versionext的方式以及压缩json的思路&#xff0c;对于我来讲都可以看得懂&#xff0c;想得通&#xff0c;其…

RUNOOB python练习题3

用来练手的python 练习题&#xff0c;原链接 : python练习实例3 拿到题目就写了如下代码&#xff0c;思路是因为使用**0.5进行开平方操作时&#xff0c;python会将数据类型自动转换为float单精度浮点型。这里利用提取其整数部分&#xff0c;来判断这个数是否是完全平方数。 z…

使用git将项目上传到github(最简单方法)

使用git将项目上传到github&#xff08;最简单方法&#xff09; 首先你需要一个github账号&#xff0c;所有还没有的话先去注册吧&#xff01; https://github.com/ 我们使用git需要先安装git工具&#xff0c;这里给出下载地址&#xff0c;下载后一路直接安装即可&#xff1…

数据库 概念详解

数据库 概念详解 一、MySQL MySQL 事务 MySQL 锁 MySQL 二、Redis 三、MongoDB 四、Memcached 转载于:https://www.cnblogs.com/guozepingboke/p/10743648.html

RUNOOB python练习题4

用来练手的python习题其四&#xff0c; 原题链接: python练习实例4 题干: 输入某年某月某日&#xff0c;判断这一天是这一年的第几天&#xff1f; 这个题目比较简单&#xff0c;只需要注意闰年和非闰年的区别就可以了。我这里使用numpy矩阵存储每个月的天数&#xff0c;之后用…

GitHub入门:如何上传与下载工程?

由于经常要在家写代码&#xff0c;所以需要有个能够方便访问代码管理工具。最近尝试了一下GitHub。经过了一翻纠结之后&#xff0c;基本上掌握了他的使用方式。 要使用GitHub需要首先在其网站上进行注册。其官方网站是https://github.com/。注册的流程在这里就不多少了&#x…

如何解决PIP命令不可用

今天想用PIP装一个python包&#xff0c;发现PIP报错&#xff0c;不是内部或外部命令。。。 遇事百度&#xff0c;有两种说法&#xff0c;一&#xff0c;没安装包&#xff0c;不管那么多命令执行了再说 在命令行输入&#xff1a;python -m ensurepip 将pip.exe文件下载下来 再pi…