博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
B1232 [Usaco2008Nov]安慰奶牛cheer 最小生成树
阅读量:4452 次
发布时间:2019-06-07

本文共 2293 字,大约阅读时间需要 7 分钟。

%%%小詹太巨啦!!!我就想直接最小生成树之后建树跑dfs,然后写跪了。。。然后看小詹博客之后恍然大悟,原来直接把边权改为w * 2 + 两边点权值就行了。

但是还是不对,为什么呢?原来我们起点走了三遍,还要加上一次。

题干:

DescriptionFarmer John变得非常懒, 他不想再继续维护供奶牛之间供通行的道路. 道路被用来连接N (5 <= N <= 10,000)个牧场, 牧场被连续地编号为1..N. 每一个牧场都是一个奶牛的家. FJ计划除去P(N-1 <= P <= 100,000)条道路中尽可能多的道路, 但是还要保持牧场之间的连通性. 你首先要决定那些道路是需要保留的N-1条道路. 第j条双向道路连接了牧场S_j和E_j (1 <= S_j <= N; 1 <= E_j <= N; S_j != E_j), 而且走完它需要L_j (0 <= L_j <= 1,000)的时间. 没有两个牧场是被一条以上的道路所连接. 奶牛们非常伤心, 因为她们的交通系统被削减了. 你需要到每一个奶牛的住处去安慰她们. 每次你到达第i个牧场的时候(即使你已经到过), 你必须花去C_i (1 <= C_i <= 1,000)的时间和奶牛交谈. 你每个晚上都会在同一个牧场(这是供你选择的)过夜, 直到奶牛们都从悲伤中缓过神来. 在早上起来和晚上回去睡觉的时候, 你都需要和在你睡觉的牧场的奶牛交谈一次. 这样你才能完成你的交谈任务. 假设Farmer John采纳了你的建议, 请计算出使所有奶牛都被安慰的最少时间. 对于你前10次的提交, 你的程序会在一部分正式的测试数据上运行, 并且返回运行的结果.Input* 第 1 行: 用空格隔开的两个整数N和P * 第 2..N+1 行: 第i+1行包含了一个整数: C_i * 第 N+2..N+P+1 行: 第 N+j+1 行包含用空格隔开的三个整数: S_j, E_j 和 L_jOutput第 1 行: 一个整数, 所需要的总时间(包含和在你所在的牧场的奶牛的两次谈话时间).Sample Input5 71010206301 2 52 3 52 4 123 4 172 5 153 5 64 5 12Sample Output176

代码:

#include
#include
#include
#include
#include
#include
using namespace std;#define duke(i,a,n) for(int i = a;i <= n;i++)#define lv(i,a,n) for(int i = a;i >= n;i--)#define clean(a) memset(a,0,sizeof(a))const int INF = 1 << 30;typedef long long ll;typedef double db;template
void read(T &x){ char c; bool op = 0; while(c = getchar(), c < '0' || c > '9') if(c == '-') op = 1; x = c - '0'; while(c = getchar(), c >= '0' && c <= '9') x = x * 10 + c - '0'; if(op) x = -x;}template
void write(T x){ if(x < 0) putchar('-'), x = -x; if(x >= 10) write(x / 10); putchar('0' + x % 10);}int p,c,n,lst[10005],len = 0;int fa[10005];struct node{ int l,r,nxt,w; bool operator < (const node &other) const { return w < other.w; }}a[200005];void add(int x,int y,int w){ a[++len].l = x; a[len].r = y; a[len].nxt = lst[x]; a[len].w = w; lst[x] = len;}int get_fa(int x){ if(fa[x] != x) return fa[x] = get_fa(fa[x]); return x;}int q[10050];int way[200005];int main(){ read(n);read(p); duke(i,1,n) { read(q[i]); } duke(i,1,n) fa[i] = i; duke(i,1,p) { int x,y,w; read(x);read(y);read(w); add(x,y,w * 2 + q[x] + q[y]); } sort(a + 1,a + len + 1); int num = 0,tot = 0; duke(i,1,len) {// cout<
<

 

转载于:https://www.cnblogs.com/DukeLv/p/9535130.html

你可能感兴趣的文章
时间复杂度和空间复杂度2 - 数据结构和算法04
查看>>
OD使用教程4 - 调试篇04|解密系列
查看>>
进位标志位
查看>>
spring boot使用slf4j输出日志
查看>>
learning gcc&gdb
查看>>
STL_算法_01_查找算法
查看>>
05-python中函数的使用
查看>>
opencv3.2.0之绘图
查看>>
VB代码(\D 正则表达式去掉数字)
查看>>
NSiS“反编译”方法-By蓝色网际
查看>>
取得绝对路径 2003 2007 Excel
查看>>
我爱 哐 哐 哐,我是哐人类!-【废话区】
查看>>
WinPE启动U盘的制作方法与软件下载(通用PE工具箱/老毛桃/大白菜WinPE)(转载)...
查看>>
行为型设计模式之5--中介者模式
查看>>
Android DevArt6:Android中IPC的六种方式
查看>>
oracle练习题
查看>>
PMP学习感想
查看>>
Zookeeper全解析——Paxos作为灵魂
查看>>
集合-强大的集合工具类:java.util.Collections中未包含的集合工具
查看>>
CSS清除浮动
查看>>