2022CCPC绵阳站A+广东站C
admin
2024-02-08 01:46:07
0

最后几天了,虽然一堆考试没复习,压力山大,不过都是小事。
这几次的vp我们发挥的还可以,稳铜了。
希望我们队在济南也能有一个好的结果,不留遗憾。

A. Ban or Pick, What’s the Trick

记忆化搜索,好久没做了。当时vp时写了个贪心,wa6了,就想到可能是dp了。
思路:
1.看到k的范围只有10,设计状态dp[round][numa][numb]:在已经进行i轮的基础上,A选了numa个英雄,B选了numb个英雄时的分数。
2.结束状态:当进行到n*2轮的时候,递归返回。
3.状态转移:由于从0开始累计操作,因此偶数轮A行动,奇数轮B行动。一个小的注意点,当A行动完,B行动的时候,需要通过(轮数+1)/2才是A行动的轮数。
4.每个人行动时,都有两种情况。选择己方英雄或ban掉对方英雄。
选择己方:res=max(res,dfs(round+1,numa+1,numb)+a[ra+1])
ban对方:res=max(res,dfs(round+1,numa,numb))此处轮数+1,但A的英雄数并没增加
5.A希望最大化分数,因此取max;B希望最小化分数,因此减去己方英雄值时候取min。

#include 
#define endl '\n'
#define int long long
#define ios (ios::sync_with_stdio(false),cin.tie(0),cout.tie(0))using namespace std;
const int N =2e5+5;
const int inf=1e18;
const int mod=1e9+7;
const double eps=1e-8;
int n,k,a[N],b[N],dp[N][15][15];
int dfs(int round,int numa,int numb)
{if(round==2*n)return 0;if(dp[round][numa][numb]!=-inf)return dp[round][numa][numb];int ra=round/2-numb+numa;int rb=(round+1)/2-numa+numb;if(round%2==0){int res=-inf;if(numaint res=inf;if(numbmemset(dp,-inf,sizeof dp);cin>>n>>k;for(int i=0;i<=2*n;i++)for(int j=0;j<=k;j++) for(int s=0;s<=k;s++) dp[i][j][s]=-inf;for(int i=1;i<=n;i++) cin>>a[i];for(int i=1;i<=n;i++) cin>>b[i];sort(a+1,a+n+1,greater());sort(b+1,b+n+1,greater());cout<ios;solve();return 0;
}

C. Customs Controls 2

1.各个点到点t的距离相同,需要从终点反向遍历,合并点集。
2.正向存边,处理得到每一个结点的度。
3.进行拓扑遍历合并后的DAG图,dp[u]表示从点1出发的路径长度。

#include 
#define endl '\n'
#define int long long
#define ios (ios::sync_with_stdio(false),cin.tie(0),cout.tie(0))
#define PII pair
#define re register
using namespace std;
const int N =7e5+5;
const int inf=1e18;
const int mod=1e9+7;
const double eps=1e-8;
int n,m,f[N],dp[N],d[N];
vectore[N],g[N];
vectormp;
int r_find(int r)
{if(f[r]==r) return f[r];f[r]=r_find(f[r]);return f[r];
}
void solve()
{cin>>n>>m;mp.clear();for(int i=0;i<=n;i++) f[i]=i,dp[i]=d[i]=0,e[i].clear(),g[i].clear();for(int i=1;i<=m;i++){int x,y;cin>>x>>y;e[y].push_back(x);mp.push_back({x,y});}for(int i=1;i<=n;i++){for(int v:e[i])f[r_find(v)]=r_find(e[i][0]);}for(auto cur:mp){int x=cur.first,y=cur.second;g[r_find(x)].push_back(r_find(y));d[r_find(y)]++;}int cnt=0;queueq;for(int i=1;i<=n;i++){if(f[i]==i){cnt++;if(d[i]==0)dp[i]=1,q.push(i);}}while(!q.empty()){int u=q.front();q.pop();cnt--;for(int v:g[u]){dp[v]=max(dp[u]+1,dp[v]);d[v]--;if(!d[v]) q.push(v);}}if(cnt) cout<<"No"<cout<<"Yes"<int ans=dp[r_find(i)];if(i!=1) ans-=dp[r_find(e[i][0])];cout<ios;int T;cin>>T;while(T--)solve();return 0;
}

相关内容

热门资讯

容芯致远获天使轮融资 2026年5月8日,北京容芯致远科技有限公司(简称“容芯致远”)宣布完成天使轮融资。本轮融资由万利达...
试管期间能运动吗?避开这些坑,... 做试管的姐妹都纠结:不动怕气血差、影响卵泡,动了又怕伤子宫、毁着床,到底该怎么办?其实试管不用“躺平...
原创 今... 2026年5月6日,国内金价算是彻底“凉”了一下,你看那AU9999现货黄金,直接跌到了1013元一...
美国5月消费者信心再创历史新低... 财联社5月8日讯(编辑 牛占林)随着中东战争持续推高能源价格,美国消费者信心本月继续下滑,并再度刷新...
“压高盛一头”!江西一精神病院... 蓝鲸新闻5月8日讯(记者 徐甘甘)5月8日,盛通股份(002599.SZ)一季报引发资本市场热议——...
2026年企业短视频能力升级:... 本篇将回答的核心问题 2026年企业短视频营销面临哪些关键挑战,有效应对策略是什么? 服务机构的能力...
江西一精神病院炒股炒成上市公司... 红星资本局5月8日消息,近日,上市公司盛通股份(002599.SZ)发布一季报,披露了前十大股东名单...
企业IP打造指南:小公司低成本... 小公司做企业IP,不是为了装门面,而是让客户在没见到你之前,就能通过内容知道你是谁、你解决什么问题、...
官方:赵心童入选世界斯诺克名人... 北京时间5月8日消息,世界斯诺克巡回赛(WST)今日正式公布了2025/26赛季年终奖项及名人堂更新...
小灰熊AI学员王锋:希望能跟上... 35了,老程序员了。 从进入互联网行业到现在,其实已经做了很多年移动端开发。最早那几年,安卓行业发展...
原创 2... 2026年全国两会把稳定房地产市场列为重点工作,政府工作报告明确提出因城施策控增量、去库存、优供给。...
一年翻倍,六年未归——徽商银行... 文:向善财经 今年的港股市场,与A股市场出现了明显的分化。 A股这边,科技板块在AI浪潮中热闹非凡;...
古井贡酒2025:在行业深度调... 以“稳”为底、以“新”为翼。 文/每日财报 杜康 在行业库存高企、价格倒挂的背景下,当多数酒企在为...
好上好8408万收购鼎瑞芯加码... 5月7日晚,好上好(001298.SZ)抛出一份收购公告,拟以8408万元现金收购深圳市鼎瑞芯科技有...
全面大撤离!李嘉诚英国“套现”... 突发,李嘉诚又卖了。 这次,套现了455亿。 金额不少,但更值得关注的是透露着不同寻常的信号。 因为...
油气价格上涨加剧法国一季度贸易... 据新华社,法国海关7日发布的数据显示,受中东局势推高国际油气价格影响,法国今年第一季度贸易逆差扩大至...
昆仑芯启动科创板IPO上市辅导... 5月8日,据证监会官网显示,昆仑芯(北京)科技股份有限公司于2026年5月7日正式启动科创板上市辅导...
贵州茅台酒股份有限公司关于回购... 来源:上海证券报 证券代码:600519 证券简称:贵州茅台 公告编号:临2026-016 贵州茅...
百度昆仑芯启动科创板上市辅导,... 5月8日,证监会官网显示,昆仑芯(北京)科技股份有限公司 (下称“昆仑芯”)于2026年5月7日正式...
滕州信华的承压时刻:罚单、失信... 2026年4月末,滕州信华美元债单日跌近2%,关联方被列“老赖”。半年前,这家AA+城投曾因非市场化...