POI2014
...一个shabi和一堆神题的故事
今天只写了两道
之后随缘更吧
啊 顺便 snake我是不会更的
bzoj3829 POI2014 Farmcraft
当先走$u$再走$v$的时候时间是$f[u] + 1 + 2 \times size[u] + f[v] + 1$
当先走$u$再走$v$的时候时间是$f[v] + 1 + 2 \times size[v] + f[u] + 1$
#include<bits/stdc++.h>
using namespace std; inline int read()
{
int x = ,f = ;char ch = getchar();
for(;!isdigit(ch);ch = getchar())if(ch == '-')f = -f;
for(;isdigit(ch);ch = getchar())x = * x + ch - '';
return x * f;
}
int n;
const int maxn = ;
int first[maxn],to[maxn << ],nx[maxn << ],cnt;
int val[maxn],size[maxn],fa[maxn];
int f[maxn];
int sons[maxn];
inline void add(int u,int v){to[++cnt] = v;nx[cnt] = first[u];first[u] = cnt;}
inline bool cmp(int u,int v){return max(f[u], * size[u] + f[v]) < max(f[v], * size[v] + f[u]);}
inline void dfs(int x)
{
size[x] = ;
for(int i=first[x];i;i=nx[i])
{
if(to[i] == fa[x])continue;
fa[to[i]] = x;dfs(to[i]);size[x] += size[to[i]];
}
int nt = ,tmp = ;
f[x] = val[x];
for(int i=first[x];i;i=nx[i]){if(to[i] == fa[x])continue;sons[++nt] = to[i];}
sort(sons + ,sons + nt + ,cmp);
for(int i=;i<=nt;++i)f[x]=max(f[x],tmp*+f[sons[i]]+),tmp+=size[sons[i]];
}
int main()
{
n = read();
for(int i=;i<=n;i++)val[i] = read();
for(int i=;i<n;i++)
{
int u = read(),v = read();
add(u,v);add(v,u);
}
dfs();
cout<<max(f[],(n-)*+val[]);
}
bzoj3832 Rally
一个DAG,每条边长度都是$1$,求删掉一个点之后最长路的最小值
输出最小值和那个点
$n \leq 500000$
$m \leq 2 \times n$
sol:神题
首先我们建超级源$S$,超级汇$T$,每个点向源汇连边$(S -> X -> T)$
这样图上最长链就变成了$S$到$T$最长链
我们可以拓扑序$dp$出每个点到$S$到$T$的最长链$f[x]$和$g[x]$
这样就是对一个割集内的每条边$(x,y)$求$f[x] + g[y]$的最大值
我们另所有点都在$T$集,$S$在$S$集
每次从$T$删一个点加入$S$
删除的时候删掉它的入边 记录答案 然后加入它的出边
具体 我们要加入一个元素 删除一个元素 查询最大值
这个用堆或者线段树都可以
#include<bits/stdc++.h>
using namespace std;
inline int read()
{
int x = ,f = ;char ch = getchar();
for(;!isdigit(ch);ch = getchar())if(ch == '-')f = -f;
for(;isdigit(ch);ch = getchar())x = * x + ch - '';
return x * f;
}
int n,m;
const int maxn = ;
struct Graph
{
int first[maxn],to[maxn << ],nx[maxn << ],cnt;
int ind[maxn],indd[maxn];
inline void add(int u,int v){to[++cnt] = v;nx[cnt] = first[u];first[u] = cnt;ind[v]++;indd[v]++;}
}G,rev;
priority_queue<int> q1,q2;
queue<int> q;
int dp[maxn],f[maxn];
inline void push(int x){q1.push(x);}
inline void del(int x){q2.push(x);while(!q1.empty() && !q2.empty() && (q1.top() == q2.top()))q1.pop(),q2.pop();}
inline int top(){if(q1.empty())return ;return q1.top();}
void toposort()
{
for(int i=;i<=n;i++)
if(G.ind[i] == )q.push(i);
while(!q.empty())
{
int now = q.front();q.pop();
for(int i=G.first[now];i;i=G.nx[i])
{
G.ind[G.to[i]]--;
dp[G.to[i]] = max(dp[G.to[i]],dp[now] + );
if(G.ind[G.to[i]] == )q.push(G.to[i]);
}
}
while(!q.empty())q.pop();
for(int i=;i<=n;i++)
if(rev.ind[i] == )q.push(i);
while(!q.empty())
{
int now = q.front();q.pop();
for(int i=rev.first[now];i;i=rev.nx[i])
{
rev.ind[rev.to[i]]--;
f[rev.to[i]] = max(f[rev.to[i]],f[now] + );
if(rev.ind[rev.to[i]] == )q.push(rev.to[i]);
}
}
}
void solve()
{
int ans = (n << ),id;
while(!q.empty())q.pop();
for(int i=;i<=n;i++)
if(G.indd[i] == )q.push(i);
while(!q.empty())
{
int now = q.front();q.pop();
del(f[now]);
for(int i=rev.first[now];i;i=rev.nx[i])del(dp[rev.to[i]] + f[now] + );
if(top() < ans)
{
ans = top();
id = now;
}
for(int i=G.first[now];i;i=G.nx[i])
{
push(f[G.to[i]] + dp[now] + );
G.indd[G.to[i]]--;
if(G.indd[G.to[i]] == )q.push(G.to[i]);
}
push(dp[now]);
}
printf("%d %d",id,ans);
}
int main()
{
n = read();m = read();
for(int i=;i<=m;i++){int u = read(),v = read();G.add(u,v);rev.add(v,u);}
toposort();
for(int i=;i<=n;i++)push(f[i]);
solve(); }
POI2014的更多相关文章
- BZOJ 3524: [Poi2014]Couriers [主席树]
3524: [Poi2014]Couriers Time Limit: 20 Sec Memory Limit: 256 MBSubmit: 1892 Solved: 683[Submit][St ...
- BZOJ 3524: [Poi2014]Couriers
3524: [Poi2014]Couriers Time Limit: 20 Sec Memory Limit: 256 MBSubmit: 1905 Solved: 691[Submit][St ...
- [BZOJ3872][Poi2014]Ant colony
[BZOJ3872][Poi2014]Ant colony 试题描述 There is an entrance to the ant hill in every chamber with only o ...
- 【BZOJ】【3522】【POI2014】Hotel
暴力/树形DP 要求在树上找出等距三点,求方案数,那么用类似Free Tour2那样的合并方法,可以写出: f[i][j]表示以 i 为根的子树中,距离 i 为 j 的点有多少个: g[i][j]表示 ...
- 【BZOJ】【3831】【POI2014】Little Bird
DP/单调队列优化 水题水题水题水题 单调队列优化的线性dp…… WA了8次QAQ,就因为我写队列是[l,r),但是实际操作取队尾元素的时候忘记了……不怎么从队尾取元素嘛……平时都是直接往进放的……还 ...
- Bzoj 3831 [Poi2014]Little Bird
3831: [Poi2014]Little Bird Time Limit: 20 Sec Memory Limit: 128 MB Submit: 310 Solved: 186 [Submit][ ...
- BZOJ3522: [Poi2014]Hotel
3522: [Poi2014]Hotel Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 195 Solved: 85[Submit][Status] ...
- 3522: [Poi2014]Hotel( 树形dp )
枚举中点x( 即选出的三个点 a , b , c 满足 dist( x , a ) = dist( x , b ) = dist( x , c ) ) , 然后以 x 为 root 做 dfs , 显 ...
- 【BZOJ3524/2223】[Poi2014]Couriers 主席树
[BZOJ3524][Poi2014]Couriers Description 给一个长度为n的序列a.1≤a[i]≤n.m组询问,每次询问一个区间[l,r],是否存在一个数在[l,r]中出现的次数大 ...
- 3522: [Poi2014]Hotel
3522: [Poi2014]Hotel Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 253 Solved: 117[Submit][Status ...
随机推荐
- mybatis性能优化之降低数据库连接
做性能优化的最重要的功能就是降低数据库的交互.非常多程序猿一般在开发的时候仅仅考虑简单的实现功能,无论业务简单复杂,仅仅要实现即可. mybatis有个重要的功能就是考虑在联合查询时技巧: <? ...
- HDMI原理图信号PIN脚
HDMI(19Pin)/DVI(16 pin)的功能是热插拔检测(HPD),这个信号将作为主机系统是否对HDMI/DVI是否发送TMDS信号的依据.HPD是从显示器输出送往计算机主机的一个检测信号.热 ...
- (最短路径算法整理)dijkstra、floyd、bellman-ford、spfa算法模板的整理与介绍
这一篇博客以一些OJ上的题目为载体.整理一下最短路径算法.会陆续的更新... 一.多源最短路算法--floyd算法 floyd算法主要用于求随意两点间的最短路径.也成最短最短路径问题. 核心代码: / ...
- HDU 5056 Boring count(数学)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5056 Problem Description You are given a string S con ...
- Thymeleaf框架
简单说, Thymeleaf 是一个跟 Velocity.FreeMarker 类似的模板引擎,它可以完全替代 JSP .相较与其他的模板引擎,它有如下三个极吸引人的特点: 1.Thymeleaf 在 ...
- U盘中毒变成exe快捷键文件不见问题
大家好,大家能够叫我阿胜,今天给我大家带一个有用小方法,希望对大家有帮助.去学校打印社打印东西,U盘中病毒,使U盘文件所有变成快捷键了,这个坑爹的打印社.这时我该怎么办...... 嘿嘿.阿胜给 ...
- LeetCode(100)题解--Same Tree
https://leetcode.com/problems/same-tree/ 题目: Given two binary trees, write a function to check if th ...
- 自动关闭AfxMessageBox对话框―模拟"回车" VC
有的时候,在程序里面调用太多的AfxMessageBox(非调试用),弹出的对话框要手动关闭,时间一长就感觉很繁琐.于是上网找了一些资料,发现有一个很简单的实现AfxMessageBox对话框自动关闭 ...
- myql 5.6 安装
环境: centos 6.5 192.168.9.28 4核4G 虚拟机 一. 安装编译源码所需要的工具和库 [root@localhost ~]# yum -y install gcc gcc- ...
- mybatis 各组件生命周期
1.SqlSessionFactoryBuilder SqlSessionFactoryBuilder是通过利用XML或者java编码来获取Configuration配置来构建SqlSessionFa ...