NOIp2013 货车运输 By cellur925
A 国有 n 座城市,编号从 1 到 n ,城市之间有 m 条双向道路。每一条道路对车辆都有重量限制,简称限重。
现在有 q 辆货车在运输货物, 司机们想知道每辆车在不超过车辆限重的情况下,最多能运多重的货物。
思路
这题思路想明白了就很简单,一句话题意:求树上两点间路线中边长最小的边权。
首先,为什么是树呢?限重肯定越大越好,因此我们可以跑出图的最大生成树(Kruskal)
之后,我们就可以对于每次询问来求出路径上的最小边权(最多能运的货物重量),这里可以用到树上倍增法(求LCA时一起求了,虽然LCA不会直接用到,但也是要一起求出来的)
至于两点间是否能互达,就可以用并查集维护一下就行了!
实现
提交记录过于真实,从0到10到65到70到95到AC Orz
可能是我常数写丑了,所以在洛谷更新评测姬前以及不开氧气优化都会T两个点??
code
#include<cstdio>
#include<algorithm>
#include<queue>
#include<cmath>
#include<cstring>
#define maxm 50090
#define maxn 10090 using namespace std; int n,m,Q,tot,t;
int head[maxn],d[maxn],f[maxn][],fa[maxn],g[maxn][];
bool vis[maxn];
struct cellur{
int f,t,w;
}e[maxm];
struct node{
int to,next,val;
}edge[maxn<<]; bool cmp(cellur a,cellur b)
{
return a.w>b.w;
} void add(int x,int y,int z)
{
edge[++tot].to=y;
edge[tot].next=head[x];
head[x]=tot;
edge[tot].val=z;
} int getf(int x)
{
if(fa[x]==x) return x;
else return fa[x]=getf(fa[x]);
} void Kruskal()
{
for(int i=;i<=n;i++) fa[i]=i;
sort(e+,e++m,cmp);
int cnt=;
for(int i=;i<=m;i++)
{
if(cnt==n-) break;
int pp=getf(e[i].f);
int qq=getf(e[i].t);
if(pp==qq) continue;
cnt++;
fa[qq]=pp;
add(e[i].f,e[i].t,e[i].w),add(e[i].t,e[i].f,e[i].w);
}
} void bfs(int s)
{
queue<int>q;
q.push(s);d[s]=;
while(!q.empty())
{
int u=q.front();q.pop();
for(int i=head[u];i;i=edge[i].next)
{
int v=edge[i].to;
if(d[v]) continue;
d[v]=d[u]+;
f[v][]=u;g[v][]=edge[i].val;
for(int j=;j<=t;j++)
{
f[v][j]=f[f[v][j-]][j-];
g[v][j]=min(g[f[v][j-]][j-],g[v][j-]);
}
q.push(v);
}
}
} int lca(int x,int y)
{
int num=1e9;
if(d[x]<d[y]) swap(x,y);
for(int i=t;i>=;i--)
if(d[f[x][i]]>=d[y]) num=min(num,g[x][i]),x=f[x][i];
if(x==y) return num;
for(int i=t;i>=;i--)
if(f[x][i]!=f[y][i])
{
num=min(num,g[x][i]);
num=min(num,g[y][i]);
x=f[x][i],y=f[y][i];
}
return min(num,min(g[x][],g[y][]));
} int main()
{
freopen("truck.in","r",stdin);
freopen("truck.out","w",stdout);
scanf("%d%d",&n,&m);
t=log2(n)+;
for(int i=;i<=m;i++)
scanf("%d%d%d",&e[i].f,&e[i].t,&e[i].w);
Kruskal();
memset(g,,sizeof(g));
for(int i=;i<=n;i++) if(!d[i]) bfs(i);
// for(int i=1;i<=n;i++) printf("%d ",g[i][2]);
// return 0;
scanf("%d",&Q);
while(Q--)
{
int x=,y=;
scanf("%d%d",&x,&y);
int pp=getf(x);
int qq=getf(y);
if(pp!=qq) {printf("-1\n");continue;}
printf("%d\n",lca(x,y));
}
return ;
}
$bfs$也能解决不连通的问题:不bfs一次,而是让每个点都有深度。
11.6考试的时候边大小开小了&&LCA写错板子了hhh
NOIp2013 货车运输 By cellur925的更多相关文章
- [Luogu 1967] NOIP2013 货车运输
[Luogu 1967] NOIP2013 货车运输 一年多前令我十分头大的老题终于可以随手切掉了- 然而我这码风又变毒瘤了,我也很绝望. 看着一年前不带类不加空格不空行的清纯码风啊,时光也好像回去了 ...
- NOIP2013 货车运输(最大生成树,倍增)
NOIP2013 货车运输(最大生成树,倍增) A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物,司机们想知道 ...
- NOIP2013 货车运输 (最大生成树+树上倍增LCA)
死磕一道题,中间发现倍增还是掌握的不熟 ,而且深刻理解:SB错误毁一生,憋了近2个小时才调对,不过还好一遍AC省了更多的事,不然我一定会疯掉的... 3287 货车运输 2013年NOIP全国联赛提高 ...
- NOIP2013 货车运输
3.货车运输 (truck.cpp/c/pas) [问题描述] A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货 ...
- Codevs3278[NOIP2013]货车运输
3287 货车运输 2013年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description A 国有 ...
- 【洛谷P1967】[NOIP2013]货车运输
货车运输 题目链接 显然,从一点走到另一点的路径中,最小值最大的路径一定在它的最大生成树上 所以要先求出最大生成树,再在生成树上找最近公共祖先,同时求出最小值. #include<iostrea ...
- noip2013货车运输
P1967 货车运输 题目描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物, 司机们想知道每辆车在不超过 ...
- NOIP2013货车运输[lca&&kruskal]
题目描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物, 司机们想知道每辆车在不超过车辆限重的情况下,最多 ...
- [noip2013]货车运输(kruskal + 树上倍增)
描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物,司机们想知道每辆车在不超过车辆限重的情况下,最多能运多 ...
随机推荐
- C/C++ (一)
c语言中的逻辑运算符都是短路运算,一旦能够确定整个表达式的值就不再计算,配合c的定义的灵活性,可以写出很多漂亮的程序. 例如 如果要在一个长为n的数列s中找到第k个没被标记过的数 for(i=1,j= ...
- Triangle(dp)
Given a triangle, find the minimum path sum from top to bottom. Each step you may move to adjacent n ...
- Spring中基于AOP的XML架构
以下内容引用自http://wiki.jikexueyuan.com/project/spring/aop-with-spring-framenwork/xml-schema-based-aop-wi ...
- HDU 1201 18岁生日 【日期】
18岁生日 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Subm ...
- Linux的基本优化
归结成口诀: 一清.一精.一增.两优.四设.七其他 一清: 定时清理日志/var/spool/clientsqueue 一精: 精简开机启动服务 一增: 增大文件描述符 两优: linux内核参数的优 ...
- iOS开发人员:事实上你还有非常多东西须要学
iOS 新特性总结(since iOS6) iOS 6 1.废除viewDidUnLoad 收到内存警告须要到didReceiveMemoryWarning中处理 [小技巧] -(void)didRe ...
- Thinking in Java -- 类型信息RTTI
Thinking in Java – 类型信息 个人感觉 java 中的比較难的部分了,在看了些netty源代码发现事实上这块很实用. 这章重点是RTTI和反射.先说下自己的理解 RTTI是执行时识别 ...
- 怎样快速刪除Word中超链接?
有时我们从网上down了一些资料,存到Word文档里,会发现一些文字和图片带有超链接.这其实是Word自动修改功能引起的麻烦,那么,有什么办法可以把这些超链接快速批量删掉吗? 步骤/方法 1 按键盘上 ...
- make运行阶段划分
1 make执行分为两个阶段 第一个阶段:读makefile并且建树阶段 第二个阶段:构建目标阶段 2 扩展的立即和推迟 在第一个阶段的扩展是立即,在第二个阶段或者在需要的时候再扩展是推迟,这里的需要 ...
- 前端富文本 js 版本
https://s3.pstatp.com/pgc/v2/resource/tt_ueditor_v3_temple/tt-editor.all.js?20180425