「ABC 218」解集
E
倒流一下,然后把负权边置零后跑 MST 即可。
#include<cstdio>
#include<vector>
#include<algorithm>
using namespace std;
const int N=2e5+5,M=2e5+5;
struct edge
{
int u,v;
long long w;
edge(int U=0,int V=0,int W=0)
{
u=U;
v=V;
w=W;
}
}tur[M];
int n,m,fa[N];
bool cmp(edge one,edge ano)
{
return one.w<ano.w;
}
int find(int u)
{
if(u^fa[u]) fa[u]=find(fa[u]);
return fa[u];
}
long long spannin()
{
long long res=0;
for(int i=1;i<=m;++i)
{
int u=tur[i].u,v=tur[i].v;
long long w=tur[i].w;
int x=find(u),y=find(v);
if(x^y)
{
fa[x]=y;
res+=w;
}
}
return res;
}
int main()
{
scanf("%d%d",&n,&m);
long long sum=0;
for(int i=1;i<=n;++i) fa[i]=i;
for(int i=1,u,v;i<=m;++i)
{
scanf("%d%d%lld",&u,&v,&tur[i].w);
tur[i].w=max(tur[i].w,0LL);
tur[i]=edge(u,v,tur[i].w);
sum+=tur[i].w;
}
sort(tur+1,tur+1+m,cmp);
printf("%lld\n",sum-spannin());
return 0;
}
F
跑出原图的最短路树,非树边删除不需要考虑,树边就重新跑一次最短路(规模 \(\Theta(n)\))。
类似的题(原题)有 JOI 2020 Final Olympic Bus。
#include<bits/stdc++.h>
int n,m,hd[500],ecnt,ont[319300],pre[500],ide[500];
struct edge {
int nxt,to;
}e[319300];
void add_edge( int x,int y ) { e[++ecnt]={hd[x],y},hd[x]=ecnt; }
int dis[500],vis[500];
std::priority_queue<std::pair<int,int>,std::vector<std::pair<int,int>>,std::greater<std::pair<int,int>>> pq;
int find( int X ) {
std::memset( dis+1,0x3f,n<<2 );
std::memset( vis+1,0,n<<2 );
for( dis[1]=0,pq.emplace( 0,1 ); pq.size(); ) {
int x=pq.top().second; pq.pop();
if( vis[x] ) continue; vis[x]=1;
for( int i=hd[x]; i; i=e[i].nxt ) {
if( i==X ) continue;
int y=e[i].to;
if( dis[y]>dis[x]+1 ) {
dis[y]=dis[x]+1;
pre[y]=x;
ide[y]=i;
if( !vis[y] ) pq.emplace( dis[y],y );
}
}
}
return dis[n]==0x3f3f3f3f?-1:dis[n];
}
signed main() {
scanf( "%d%d",&n,&m );
for( int i=1,x,y; i<=m; ++i ) scanf( "%d%d",&x,&y ),add_edge( x,y );
int ret=find( -1 );
if( ret==-1 ) {
for( int i=1; i<=m; ++i ) puts( "-1" );
return 0;
}
for( int now=n; now!=1; ) ont[ide[now]]=1,now=pre[now];
for( int i=1; i<=m; ++i ) {
if( ont[i] ) printf( "%d\n",find( i ) );
else printf( "%d\n",ret );
}
return 0;
}
G
其实五分钟能冲出来的……去了板子码长 800B。
跑出每个结点到根的中位数,这个随便拿个数据结构维护下就行了,然后做个树 DP,就考虑深度奇偶性,和 P7443 的那个 SG 函数一个套路。注意是自底向上跑的。
#include<bits/stdc++.h>
struct btree {
int ch[100100][2],fa[100100],val[100100],cnt[100100],sz[100100],tot,root;
btree() { ins( std::numeric_limits<int>::max() ),ins( std::numeric_limits<int>::min() ); }
bool wis( int p ) { return ch[fa[p]][1]==p; }
void pull( int p ) { sz[p]=sz[ch[p][0]]+sz[ch[p][1]]+cnt[p]; }
int dot( int v ) { return val[++tot]=v,sz[tot]=cnt[tot]=1,tot; }
void link( int f,int p,int k ) { ch[f][k]=p,fa[p]=f; }
void rot( int p ) {
int f=fa[p],gf=fa[fa[p]],k=wis( p );
link( gf,p,wis( f ) ),link( f,ch[p][k^1],k ),link( p,f,k^1 );
pull( f ),pull( p );
}
void splay( int p,int t ) {
for( ; fa[p]!=t; rot( p ) )
if( fa[fa[p]]!=t ) rot( wis( p )!=wis( fa[p] )?p:fa[p] );
if( t==0 ) root=p;
}
int find( int v ) {
int p=root;
if( !p ) return 0;
while( ch[p][v>val[p]] && v!=val[p] ) p=ch[p][v>val[p]];
return splay( p,0 ),p;
}
void ins( int v ) {
int p=root,f=0;
while( p && v!=val[p] ) f=p,p=ch[p][v>val[p]];
if( p ) cnt[p]++;
else fa[p=dot(v)]=f,( f && ( ch[f][v>val[f]]=p ) );
splay( p,0 );
}
int boundary( int v,int f ) { // f: 0 - pre, 1 - suf
int p=find( v );
if( ( val[p]>v && f ) || ( val[p]<v && !f ) ) return p;
p=ch[p][f];
while( ch[p][f^1] ) p=ch[p][f^1];
return p;
}
void del( int v ) {
int pre=boundary( v,0 ),suf=boundary( v,1 );
splay( pre,0 ),splay( suf,pre );
if( cnt[ch[suf][0]]>1 ) cnt[ch[suf][0]]--,pull( suf ),splay( ch[suf][0],0 );
else ch[suf][0]=0,pull( suf ),splay( suf,0 );
}
int id( int i ) {
int p=root; i++;
if( sz[p]<i ) return -1;
while( 233 ) {
if( sz[ch[p][0]]+cnt[p]<i ) i-=sz[ch[p][0]]+cnt[p],p=ch[p][1];
else if( sz[ch[p][0]]<i ) return val[p];
else p=ch[p][0];
}
return -1;
}
}tr;
int n,a[100100],med[100100],dp[100100];
std::vector<int> g[100100];
void dfs( int x,int f,int d ) {
tr.ins( a[x] );
if( d&1 ) med[x]=tr.id( ( d+1 )/2 );
else med[x]=( tr.id( d/2 )+tr.id( d/2+1 ) )/2;
for( int y:g[x] ) if( y!=f ) dfs( y,x,d+1 );
tr.del( a[x] );
}
void DP( int x,int f,int d ) {
int leaf=1,mx=0,mn=1e9;
for( int y:g[x] ) if( y!=f && ( leaf=0 )^1 )
DP( y,x,d+1 ),mx=std::max( mx,dp[y] ),mn=std::min( mn,dp[y] );
if( leaf ) dp[x]=med[x];
else dp[x]=( d&1 )?mx:mn;
}
signed main() {
scanf( "%d",&n ); for( int i=1; i<=n; ++i ) scanf( "%d",&a[i] );
for( int i=1,x,y; i<n; ++i ) scanf( "%d%d",&x,&y ),g[x].emplace_back( y ),g[y].emplace_back( x );
dfs( 1,0,1 ),DP( 1,0,1 ),printf( "%d\n",dp[1] );
return 0;
}
H 不会 wqs / 反悔贪心,改天学下再说吧……
是不是有点水了呀……
「ABC 218」解集的更多相关文章
- Solution Set -「ABC 217」
大家好屑兔子又来啦! [A - Lexicographic Order] 说个笑话,\(\color{black}{\text{W}}\color{red}{\text{alkingDead} ...
- Solution -「ABC 219H」Candles
\(\mathcal{Description}\) Link. 有 \(n\) 支蜡烛,第 \(i\) 支的坐标为 \(x_i\),初始长度为 \(a_i\),每单位时间燃烧变短 \(1\) ...
- Solution -「ABC 215H」Cabbage Master
\(\mathcal{Description}\) Link. 有 \(n\) 种颜色的,第 \(i\) 种有 \(a_i\) 个,任意两球互不相同.还有 \(m\) 个盒子,每个盒子可以被放 ...
- Solution -「ABC 213G」Connectivity 2
\(\mathcal{Description}\) Link. 给定简单无向图 \(G=(V,E)\),点的编号从 \(1\) 到 \(|V|=n\).对于 \(k=2..n\),求 \(H= ...
- Solution -「ABC 213H」Stroll
\(\mathcal{Description}\) Link. 给定一个含 \(n\) 个结点 \(m\) 条边的简单无向图,每条边的边权是一个常数项为 \(0\) 的 \(T\) 次多项式, ...
- 「ABC 249Ex」Dye Color
考虑停时定理. 初始势能为 \(\sum \Phi(cnt_i)\),末势能为 \(\Phi(n)\),我们希望构造这样一个 \(\Phi:Z\to Z\) 函数,使得每一次操作期望势能变化量为常数. ...
- Solution -「ABC 217」题解
D - Cutting Woods 记录每一个切割点,每次求前驱后驱就好了,注意简单判断一下开闭区间. 考场上采用的 FHQ_Treap 无脑莽. #include <cstdio> #i ...
- Linux 小知识翻译 - 「DNS服务器」
这次聊聊「DNS服务器」. DNS(Domain Name System)服务器,也被称为域名服务器. 因为使用互联网的时候,必须要指定DNS服务器,所以你一定听过DNS这个名字吧. 那么,这个DNS ...
- 「BZOJ 4502」串
「BZOJ 4502」串 题目描述 兔子们在玩字符串的游戏.首先,它们拿出了一个字符串集合 \(S\),然后它们定义一个字符串为"好"的,当且仅当它可以被分成非空的两段,其中每一段 ...
- 「C语言」常量和变量的表示、应用和变量命名规则
在程序运行中,其值不能改变的量成为常量. 在基本数据类型中,常量可分为整型常量.实型常量.符号常量和字符型常量(包括字符常量和字符串常量),现分别介绍如下: 目录: 一.常量 二.C语言标识符 三.变 ...
随机推荐
- JavaSE线程基础
1.线程概念 2.线程创建方式 1.继承thread 2.实现runnable runnable使用最多 3.线程的生命周期及线程的状态 新建状态 就绪状态的线程(已获得所有资源,栈堆内存空间),即s ...
- 《数据结构》之栈和堆结构及JVM简析
导言: 在数据结构中,我们第一了解到了栈或堆栈,它的结构特点是什么呢?先进后出,它的特点有什么用呢?我们在哪里可以使用到栈结构,栈结构那么简单,使用这么久了为什么不用其它结构替代? 一.程序在内存中的 ...
- Windows操作系统中常用的Dos命令
打开CMD的方式: Win+R 输入cmd打开控制台(推荐使用) 在任意文件夹下,按住shift键,点击鼠标右键,选择在此处打开命令行窗口 在资源管理器的地址栏路径前面加上cmd+空格: 常用的Dos ...
- P1751 贪吃虫 题解
题意: 题目传送门 在一棵 n 个结点的树上,有 k 个贪吃虫去吃食物. 每个贪吃虫都走到达食物的唯一路径. 当一条贪吃虫通向食物的道路上有另一条贪吃虫,则较远的那只停止移动. 多条贪吃虫要进入同一节 ...
- 数位DP?记忆化罢了!
我看了半天的数位 DP,DP 没学会,人倒是麻了. 解决什么 一般用于求解给你一个区间 \([l,r]\),问你其中满足条件的数有多少个. 这种题目还是蛮常见的,我们一般情况下暴力只能拿一少部分分,之 ...
- JavaScript 整理的基础的方法
innerHTML //innerHTML 属性设置或返回表格行的开始和结束标签之间的 HTML. innertext//innerText 属性返回文本值 没有结构信息 $("#test& ...
- 解读XML - Foreach循环
<foreach item="item" index="index" collection="supplyIdAry" open=&q ...
- Llama 2 来袭 - 在 Hugging Face 上玩转它
引言 今天,Meta 发布了 Llama 2,其包含了一系列最先进的开放大语言模型,我们很高兴能够将其全面集成入 Hugging Face,并全力支持其发布. Llama 2 的社区许可证相当宽松,且 ...
- pywintypes.com_error: (-2147418111, '被呼叫方拒绝接收呼叫。', None, None)
将打开的excel全部关闭,即可解决问题.
- java.sql.SQLException: ORA-28040: 没有匹配的验证协议
一直以来用的都是服务器上的Oracle数据库,今天改成连接本地Oracle 12c数据库是出问题了.hibernate连接Oracle12c时出现 java.sql.SQLException: ORA ...