~~~题面~~~

题解:

  这题想法简单,,,写起来真的是失智,找了几个小时的错误结果是inf没开到LL范围。。。。

  首先我们需要找到任意两点之间能够携带黄金的上限值,因为是在经过的道路权值中取min,我们要使得这个min值最大,就应该要在最大生成树上寻找正确的边。求出最大生成树后我们需要在上面倍增寻找权值最小的边,这条边的权值即为携带黄金的上限值。

  于是你可以写最大生成树也可以写kruskal重构树,这里我写的是kruskal重构树,这样以来,因为kruskal重构树的性质,我们只需要寻找对应2个节点的lca,这个lca的点权即为我们要找的值。

  但是注意到题中有一些点可以被列车连通,因为在这些被联通的点之间移动不会带来任何限制,因此我们可以把这些有列车的节点看做一个点(缩点)

  然后注意到题目要求的仅仅是每个卖黄金的地方卖出的黄金数,而且在任意地方买卖的黄金并没有任何其他限制(如价格之类的),因此我们可以每到一个地方就买光所有黄金,然后如果带不到下一个地方去,我们就当我们之前没买过,对道路的上限取min即可。如果最后黄金有剩余,我们也可以直接当做我们没买过。

  于是这题就做完了。

 #include<bits/stdc++.h>
using namespace std;
#define R register int
#define AC 501000
#define ac 1001000
#define LL long long
#define inf 1000000000000000LL//!!!!!!!!!!!!!!!!!!!!!
/*因为只需要关心卖出了多少,所以遇到买入的就能买就买,如果要丢弃就当我没买过,
如果有剩余也当我没买过,然后有列车的点可以相互到达,所以就缩点缩起来,然后有路上有负载上限,
所以就跑最大生成树(重构树),然后倍增查最大上限是多少,把剩余黄金对上限取min即可。*/ int n, m, q, cnt, who;
LL have;
int Head[ac], date[ac], Next[ac], tot;
int father[AC], vis[AC], belong[AC], dep[ac];
LL f[ac][], power[ac];//点权or边权(叶节点就是点权,不然就是边权) struct road{
int x, y;LL dis;
}way[ac]; inline bool cmp(road a, road b){
return a.dis > b.dis;
} inline int read()
{
int x = ;char c = getchar(); bool z = false;
while(c > '' || c < '') {
if(c == '-') z = true;
c = getchar();
}
while(c >= '' && c <= '') x = x * + c - '', c = getchar();
if(!z) return x;
else return -x;
} inline int find(int x){
if(father[x] == x) return x;
else return father[x] = find(father[x]);
} inline void add(int f, int w){
date[++tot] = w, Next[tot] = Head[f], Head[f] = tot, father[w] = f;
//printf("%d ---> %d : %d\n", f, w, power[cnt]);
} inline void upmin(LL &a, LL b){
if(b < a) a = b;
} void kruskal()//重构树
{
int b = * n;
for(R i = ; i <= b; i ++) father[i] = i;
for(R i = ; i <= m; i ++)
{
int fx, fy;
fx = find(belong[way[i].x]), fy = find(belong[way[i].y]);
if(fx == fy) continue;
power[++cnt] = way[i].dis;
//printf("%d %d %d\n", way[i].x, way[i].y, way[i].dis);
add(cnt, fx), add(cnt, fy);
}
power[cnt + ] = inf, dep[cnt] = , f[cnt][] = cnt;
} void dfs(int x)//倍增
{
int now;
// printf("!!!%d\n", power[x]);
for(R i = ; i <= ; i ++)
f[x][i] = f[f[x][i - ]][i - ];
for(R i = Head[x]; i; i = Next[i])
now = date[i], f[now][] = x, dep[now] = dep[x] + , dfs(now);
} int lca(int x, int y)//要先倍增找到最小上限
{
if(dep[x] < dep[y]) swap(x, y);
for(R i = ; i >= ; i --)
if(dep[f[x][i]] >= dep[y]) x = f[x][i];
for(R i = ; i >= ; i --)
if(f[x][i] != f[y][i])
x = f[x][i], y = f[y][i];
if(x != y) return power[f[x][]];
else return power[x];
} void go(int f, int w)
{
LL lim = (belong[f] == belong[w]) ? inf : lca(belong[f], belong[w]);
/*if(find(belong[f]) != find(belong[w]))
{
for(R i = w; i <= n; i ++) printf("0\n");
exit(0);
}*/
upmin(have, lim);
if(power[w] > ) have += power[w];
else
{
if(have > - power[w])
have += power[w], printf("%lld\n", -power[w]);
else printf("%lld\n", have), have = ;
}
} void pre()
{
n = cnt = read(), m = read(), q = read();
for(R i = ; i <= n; i ++) vis[i] = read(), belong[i] = i;//读入每个城市的访问顺序
for(R i = ; i <= n; i ++) power[i] = read();//读入每个城市的订单
for(R i = ; i <= m; i ++)//读入边
way[i].x = read(), way[i].y = read(), way[i].dis = read();
for(R i = ; i <= q; i ++)//读入有列车的城市
{
int a = read();
if(!who) who = a;
belong[a] = who;
}
sort(way + , way + m + , cmp);
} void work()
{
if(power[vis[]] > ) have = power[vis[]];
else printf("0\n");
for(R i = ; i < n; i ++) go(vis[i], vis[i + ]);
} int main()
{
// freopen("in.in", "r", stdin);
pre();
kruskal();
dfs(cnt);
work();
// fclose(stdin);
return ;
}

[SCOI2013]摩托车交易 kruskal重构树(最大生成树) 倍增的更多相关文章

  1. isaster(Comet OJ - Contest #11D题+kruskal重构树+线段树+倍增)

    目录 题目链接 思路 代码 题目链接 传送门 思路 \(kruskal\)重构树\(+\)线段树\(+\)倍增 代码 #include <set> #include <map> ...

  2. loj2718 「NOI2018」归程[Kruskal重构树+最短路]

    关于Kruskal重构树可以翻阅本人的最小生成树笔记. 这题明显裸的Kruskal重构树. 然后这题限制$\le p$的边不能走,实际上就是要满足走最小边权最大的瓶颈路,于是跑最大生成树,构建Krus ...

  3. kruskal重构树学习笔记

    \(kruskal\) 重构树学习笔记 前言 \(8102IONCC\) 中考到了,本蒟蒻不会,所以学一下. 前置知识 \(kruskal​\) 求最小(大)生成树,树上求 \(lca​\). 算法详 ...

  4. Kruskal重构树入门

    这个知识点好像咕咕咕了好长了..趁还没退役赶紧补一下吧.. 讲的非常简略,十分抱歉.. 前置知识 Kruskal算法 一定的数据结构基础(如主席树) Kruskal重构树 直接bb好像不是很好讲,那就 ...

  5. LOJ.2718.[NOI2018]归程(Kruskal重构树 倍增)

    LOJ2718 BZOJ5415 洛谷P4768 Rank3+Rank1无压力 BZOJ最初还不是一道权限题... Update 2019.1.5 UOJ上被hack了....好像是纯一条链的数据过不 ...

  6. UVA1265 Tour Belt Kruskal重构树、倍增、树上差分

    题目传送门 题意:定义$Tour \, Belt$为某张图上的一个满足以下条件的点集:①点集中至少有$2$个点②任意两点互相连通③图上两个端点都在这个点集中的边的权值的最小值严格大于图上只有一个端点在 ...

  7. [IOI2018]狼人——kruskal重构树+可持久化线段树

    题目链接: IOI2018werewolf 题目大意:给出一张$n$个点$m$条边的无向图,点和边可重复经过,一个狼人初始为人形,有$q$次询问,每次询问要求人形态只能处于编号不小于$L$的点,狼形态 ...

  8. BZOJ5415[Noi2018]归程——kruskal重构树+倍增+堆优化dijkstra

    题目描述 本题的故事发生在魔力之都,在这里我们将为你介绍一些必要的设定. 魔力之都可以抽象成一个 n 个节点.m 条边的无向连通图(节点的编号从 1 至 n).我们依次用 l,a 描述一条边的长度.海 ...

  9. LOJ #2718. 「NOI2018」归程(Dijkstra + Kruskal重构树 + 倍增)

    题意 给你一个无向图,其中每条边有两个值 \(l, a\) 代表一条边的长度和海拔. 其中有 \(q\) 次询问(强制在线),每次询问给你两个参数 \(v, p\) ,表示在 \(v\) 出发,能开车 ...

随机推荐

  1. STM32堆栈指针疑问

    1. 下面的代码看的不是很明白,百为stm32开发板光盘\测试程序\CortexM3\Mode_Privilege\project,堆是程序员分配和使用的,栈是编译器指定的,存放函数参数,临时变量. ...

  2. 鸡啄米:C++编程之十三学习之类与对象,类的声明,成员的访问控制

    1. 本次学习鸡啄米课程第13篇,把比较重要的学习记录下来,以敦促自己更好的学习.推荐他们的网址学习:http://www.jizhuomi.com/school/c/97.html 2. 在面向过程 ...

  3. ubuntu14.04上安装Java

    apt-get安装 sudo add-apt-repository ppa:webupd8team/java sudo apt-get update sudo apt-get install orac ...

  4. nodejs 事件机制

    node 事件机制   一 三种定时器 NodeJS中有三种类型的定时器:超时时间.时间间隔.即时定时器 1.超时时间:setTimeout(callback,delayMilliSeconds,[a ...

  5. HDU - 3415(DP + 单调队列)

    链接:HDU - 3415 题意:给出一个包含 n 个数的环,求满足长度大于 0 小于等于 k 的最大区间和. 题解:将数组加倍,形成环.求一个前缀和sum.枚举每一个sum[i],以 i 结尾的最大 ...

  6. 【shell 练习4】编写Shell用户管理脚本(二)

    一.创建.删除.查看用户,随机生成八位数密码 #!/bin/bash #Author:yanglt #!/bin/bash #Author:yanglt #Blog:https://www.cnblo ...

  7. 使用 Gradle 配置java项目

    注意点 除非调试,不要print ,否则任务不会按照依赖的顺序执行,因为我们自己喜欢调试用print,但是会打乱执行顺序. 排除测试文件: sourceSets.main.java { srcDir ...

  8. ThinkPHP - 3 - IDE选择以及Eclipse PDT打开ThinkPHP项目

    ThinkPHP框架已部署到SAE(新浪云),且代码已获取到本地.眼前面临的问题就是,对ThinkPHP项目选择哪种开发工具(IDE)? 经过简单的查找比较,以及电脑里已装有Eclipse的因素,遂决 ...

  9. 软件工程第四周作业-PSP

    psp表格 类别 内容 开始时间 结束时间 中断时间 delta时间 学习 学习C# 10.6下午7:00 10.6下午8:00 - 60min 写代码 写主函数以及一些小的方法 10.7下午2:00 ...

  10. Alpha发布-----欢迎来怼团队

    欢迎来怼项目小组—Alpha发布展示 一.小组成员 队长:田继平 成员:葛美义,王伟东,姜珊,邵朔,冉华 ,李圆圆 二.文案+美工展示 链接:http://www.cnblogs.com/wwd199 ...