3287 货车运输

2013年NOIP全国联赛提高组

时间限制: 1 s    空间限制: 128000 KB    题目等级 : 钻石 Diamond

题目描述 Description

A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路。每一条道路对车辆都有重量限制,简称限重。现在有 q 辆货车在运输货物,司机们想知道每辆车在不超过车辆限重的情况下,最多能运多重的货物。

输入描述 Input Description

第一行有两个用一个空格隔开的整数 n,m,表示 A 国有 n 座城市和 m 条道路。
接下来 m 行每行 3 个整数 x、y、z,每两个整数之间用一个空格隔开,表示从 x 号城市到 y 号城市有一条限重为 z 的道路。注意:x 不等于 y,两座城市之间可能有多条道路。
接下来一行有一个整数 q,表示有 q 辆货车需要运货。
接下来 q 行,每行两个整数 x、y,之间用一个空格隔开,表示一辆货车需要从 x 城市运输货物到 y 城市,注意:x 不等于 y。

输出描述 Output Description

输出共有 q 行,每行一个整数,表示对于每一辆货车,它的最大载重是多少。如果货车不能到达目的地,输出-1。

样例输入 Sample Input

4 3 
1 2 4 
2 3 3 
3 1 1 
3
1 3 
1 4 
1 3

样例输出 Sample Output

3
-1
3

数据范围及提示 Data Size & Hint

对于 30%的数据,0 < n < 1,000,0 < m < 10,000,0 < q < 1,000; 
对于 60%的数据,0 < n < 1,000,0 < m < 50,000,0 < q < 1,000; 
对于 100%的数据,0 < n < 10,000,0 < m < 50,000,0 < q < 30,000,0 ≤ z ≤ 100,000。

 #include<bits/stdc++.h>
using namespace std;
#define maxn 10010
#define maxm 50010
struct Edge{
int from,to,value,next;
bool operator < (const Edge& a)const {
return value>a.value;}
}e[maxm],ee[maxm];
int n,m,fa[maxn],f[maxn][],deep[maxn],temp;
int head[maxn],tot,Q,num,dis[maxm][];
void Built_Map(){
for(int i=,x,y,w;i<=m;i++){
scanf("%d%d%d",&x,&y,&w);
e[i].from=x;e[i].to=y;e[i].value=w;
}
} int find(int x){
if(x==fa[x]) return x;
else return fa[x]=find(fa[x]);
}
void Add_Eedge(int u,int v,int w){
ee[++num].from=u;ee[num].value=w;ee[num].to=v;
ee[num].next=head[u];head[u]=num;
}
void Kursual(){
sort(e+,e+m+);int cur=;
for(int i=;i<=n;i++) fa[i]=i;
for(int i=;i<=m;i++){
int u=e[i].from,v=e[i].to;
int rx=find(u),ry=find(v);
if(rx != ry){
cur++;fa[rx]=ry;
Add_Eedge(u,v,e[i].value);
Add_Eedge(v,u,e[i].value);
}
if(cur == n-)break;
}
}
void DFS(int now,int from,int deepth,int ktwo){
f[now][]=from;deep[now]=deepth;
dis[now][]=ktwo;
for(int i=head[now];i;i=ee[i].next)
if(ee[i].to!=from)
DFS(ee[i].to,now,deepth+,ee[i].value);
}
void Get_Fa(){
for(int i=;i<=;i++)
for(int j=;j<=n;j++){
f[j][i]=f[ f[j][i-] ][i-];
dis[j][i]=min(dis[j][i],dis[f[j][i-]][i-]);
dis[j][i]=min(dis[j][i],dis[j][i-]);
}
}
int get_same(int a,int t){
for(int i=;i<;i++)
if(t&(<<i)){
temp=min(temp,dis[a][i]);
a=f[a][i];
}
return a;
}
int LCA_Judge(int u,int v){
if(u!=&&deep[u]==) return -;
if(v!=&&deep[v]==) return -;
temp=0x3f3f3f3f;
if(deep[u]<deep[v]) swap(u,v);
u=get_same(u,deep[u]-deep[v]);
if(u==v) return temp;
for(int i=;i>=;i--){
if(f[u][i]!=f[v][i]){
temp=min(temp,dis[u][i]);
temp=min(temp,dis[v][i]);
u=f[u][i];v=f[v][i];
} }
temp=min(temp,dis[u][]);
temp=min(temp,dis[v][]);
return temp;
}
int main()
{
scanf("%d%d",&n,&m);
memset(dis,0x3f,sizeof dis);
Built_Map();
Kursual();// 生成一张最大生成树 保存在ee 边表中
DFS(,,,);dis[][]=0x3f3f3f3f;
Get_Fa();
scanf("%d",&Q);
for(int i=,x,y;i<=Q;i++){
scanf("%d%d",&x,&y);
printf("%d\n",LCA_Judge(x,y));
}
return ;
}

思路:先跑一遍最大生成树,再通过LCA查询判断。刚是我是想查询出最近公共祖先然后从图上跑一边,查询最小值,但又觉得不太好实现,看了几位大神的博客,巧妙的处理出了dis数组,就像f数组一样,可以通过倍增处理出来,优化了不少,估计考场上能想出是最大生成树+LCA的不少,相处dis数组的没几个。

其实跑最大生成树的那个边表没必要建双向边和head数组,刚开始我全给他建上了,导致我村最大生成树的边表的head数组用link数组代替的,问题就来了,link数组,在我的IDE上没问题没交上去就CE,唉!!!!!幸亏不是考试,要是CCF的老爷机也有这毛病我就杯具了。。。

还有这是个好题,值得好好看看,好久没有敲这么长的代码了,爽!!!!!

Codevs 3287 货车运输 == 洛谷P1967的更多相关文章

  1. Codevs 3287 货车运输 2013年NOIP全国联赛提高组(带权LCA+并查集+最大生成树)

    3287 货车运输 2013年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 传送门 题目描述 Description A 国有 n 座 ...

  2. Codevs 3287 货车运输

    题目描述 Description A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物,司机们想知道每辆车在不超过 ...

  3. codevs 3287 货车运输 NOIP2013提高组

    题目链接:http://codevs.cn/problem/3287/ 题解: 和bzoj3732一毛一样,只不过是找最大生成树和最小值罢了,具体参见我的bzoj3732的博客 #include< ...

  4. 货车运输-洛谷-1967-LCA+最大生成树(kruskal(并查集))

    传送门 一道:LCA+最大生成树 个人认为把这两个的板子写好(并熟练掌握了之后)就没什么难的 (但我还是de了好久bug)qwq 最大生成树:其实就是最小生成树的变形 我用的是kruskal (个人觉 ...

  5. 洛谷 P1967 货车运输

    洛谷 P1967 货车运输 题目描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物, 司机们想知道每辆车在 ...

  6. 【杂题总汇】NOIP2013(洛谷P1967) 货车运输

    [洛谷P1967] 货车运输 重做NOIP提高组ing... +传送门-洛谷P1967+ ◇ 题目(copy from 洛谷) 题目描述 A国有n座城市,编号从1到n,城市之间有m条双向道路.每一条道 ...

  7. 洛谷P3379lca,HDU2586,洛谷P1967货车运输,倍增lca,树上倍增

    倍增lca板子洛谷P3379 #include<cstdio> struct E { int to,next; }e[]; ],anc[][],log2n,deep[],n,m,s,ne; ...

  8. 【题解】【洛谷 P1967】 货车运输

    目录 洛谷 P1967 货车运输 原题 题解 思路 代码 洛谷 P1967 货车运输 原题 题面请查看洛谷 P1967 货车运输. 题解 思路 根据题面,假设我们有一个普通的图: 作图工具:Graph ...

  9. 【题解】洛谷P1967 [NOIP2013TG] 货车运输(LCA+kruscal重构树)

    洛谷P1967:https://www.luogu.org/problemnew/show/P1967 思路 感觉2013年D1T3并不是非常难 但是蒟蒻还是WA了一次 从题目描述中看出每个点之间有许 ...

随机推荐

  1. if...else...这段代码打印结果,并简述其理由

    var age = 20; if (age >= 6) { console.log('teenager'); } else if (age >= 18) { console.log('ad ...

  2. 【最大流】bzoj1711: [Usaco2007 Open]Dining吃饭

    正在网络流入门(原来这种题用网络流做) Description 农夫JOHN为牛们做了很好的食品,但是牛吃饭很挑食. 每一头牛只喜欢吃一些食品和饮料而别的一概不吃.虽然他不一定能把所有牛喂饱,他还是想 ...

  3. C#基础-数组

    数组定义 定义数组并赋值 int[] scores = { 45, 56, 78, 98, 100 }; //在定义数组时赋值 for(int i = 0; i < scores.Length; ...

  4. 03Qt信号与槽(2)

    1. 元对象工具 ​ 元对象编译器 MOC(meta object compiler)对 C++ 文件中的类声明进行分析并产生用于初始化元对象的 C++ 代码,元对象包含全部信号和槽的名字及指向这些函 ...

  5. jCarousel,jQuery下的滚动切换传送插件

    转自:http://www.zhangxinxu.com/jq/jcarousel_zh/#Examples 介绍 jCarousel是一款 jQuery 插件, 用来控制水平或垂直排列的列表项. 这 ...

  6. GoF23种设计模式之行为型模式之责任链模式

    一.概述 使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系.将这些对象连成一条链,并且沿着这条链传递请求,直到有一个对象处理它为止.其设计思想是:给对多个对象处理一个请求的机会, ...

  7. matplotlib学习记录 四

    # 绘制3月每天最高温和10月每天最高温散点图 from matplotlib import pyplot as plt # 让matplotlib能够显示中文 plt.rcParams['font. ...

  8. POJ:2109-Power of Cryptography(关于double的误差)

    Power of Cryptography Time Limit: 1000MS Memory Limit: 30000K Description Current work in cryptograp ...

  9. MVC&JQuery如何根据List动态生成表格

    背景:在编码中,常会遇到根据Ajax的结果动态生成Table的情况,本篇进行简要的说明.这已经是我第4.5篇和Ajax有关的随笔了,互相之间有很多交叠的地方,可自行参考. 后台代码如下: public ...

  10. BZOJ 3590: [Snoi2013]Quare

    首先有一个性质,一个双联通图一定可以拆成一个小的双联通子图和一条链 一个点可以视为权值为0的双联通图或者一个点的链 状压DP,枚举子集 O(3^n*n^2) #include<cstdio> ...