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年1月24日蛋价:蛋价“火箭”上涨,破3入4! 近日,国内鸡蛋市场,蛋价迎来了“春天”,受春...
原创 得... 特朗普上台不久,就将目光锁定在格陵兰岛——对他而言,这不仅仅是一块冰封的土地,而是一枚战略棋子,足以...
面临裁员无可奈何,亚马逊员工内... 来源:市场资讯 (来源:IT之家) IT之家 1 月 24 日消息,据《商业内幕》(Business...
2026投资指南,嘉实基金投策... 来源:时代周报-时代在线 2026年是“十五五”规划的开局之年,也是布局中国经济高质量发展红利的关键...
2026年首家!又一具身智能企... 1月23日,记者获悉,星海图(北京)人工智能科技有限公司已于2026年1月完成工商变更,正式更名为“...
原创 历... 在历经千年战争的漫长历史中,有一种特殊的战斗形式至今依旧困扰着军事指挥官们,那就是攻城战。从古至今,...
宁德时代钠电池量产上车,“钠锂... 1月22日,宁德时代正式推出行业首款量产钠离子电池(以下简称“钠电池”),这款适配小微卡、中小VAN...
“十四五”营收利润显著增长,宜... 来源:市场资讯 (来源:云酒头条) 在全国白酒行业普遍承压的背景下,作为川酒核心产区的宜宾,其...
白银价格持续上涨 工厂加班赶制... 本文转自【央视财经】; 国际银价创出历史新高的同时,国内银价也持续飙升,2025年至今以来,同比上涨...
芯片巨头,暴跌超17%! 周五(1月23日),美股三大股指收盘涨跌不一。 截至收盘,道琼斯工业指数跌0.58%报49098.7...
原创 从... 小时候读《范进中举》,总觉得那个故事荒诞可笑、夸张至极。范进那时候几乎废寝忘食地读书,却依旧困窘潦倒...
证监会1号罚单!余韩,被罚没超... 1月23日,证监会发布了2026年的1号罚单。 罚单显示,2019年6月至2024年8月期间,余韩控...
柯尼卡美能达智慧医疗自助打印解... (1月23日,上海) 在国家“互联网+医疗健康”政策的大力推动下,中国各级医院的数字化转型步入快车道...
新董事长操盘,中国移动新成立两... 通信老柳2026-01-24 10:29:00 据悉,中国移动新董事长上任后对内部进行了一系列管理创...
再现13.08%反对票!村镇银... 来源:每日经济新闻 13.08%的反对票比例,近日在苏州农商行2026年第一次临时股东会上,吸收合并...
币安考虑重启美股代币 全球加密... 来源:滚动播报 全球多家大型加密货币交易所正竞相推出可追踪美股走势的加密代币交易服务,打造出一个不受...
男子用SIM卡炼出近200克黄... 1月20日,广东一男子用170多公斤的手机SIM卡芯片废料,经过一系列复杂工序后,成功炼出191.7...
全国共有395家网约车平台公司... 据网约车监管信息交互系统监测,截至2025年12月31日,全国共有395家网约车平台公司取得网约车平...
原创 俄... 买岛惹争议,关税当杠杆 这事儿的起点,其实很“特朗普”:把地缘政治当成一笔能谈的交易。 特朗普在20...
原创 黄... 以前,苹果一直是台积电的最大客户,其贡献的营收占台积电的总营收,超过20%,妥妥的最大金主。 所以对...