「洛谷P3931」 SAC E#1 - 一道难题 Tree
P3931 SAC E#1 - 一道难题 Tree
题目背景
冴月麟和魏潇承是好朋友。
题目描述
冴月麟为了守护幻想乡,而制造了幻想乡的倒影,将真实的幻想乡封印了。任何人都无法进入真实的幻想乡了,但是她给前来救她的魏潇承留了一个线索。
她设置了一棵树(有根)。树的每一条边上具有割掉该边的代价。
魏潇承需要计算出割开这棵树的最小代价,这就是冴月麟和魏潇承约定的小秘密。
帮帮魏潇承吧。
注:所谓割开一棵有根树,就是删除若干条边,使得任何任何叶子节点和根节点不连通。
输入输出格式
输入格式:
输入第一行两个整数n,S表示树的节点个数和根。
接下来n-1行每行三个整数a、b、c,表示a、b之间有一条代价为c的边。
输出格式:
输出包含一行,一个整数,表示所求最小代价。
输入输出样例
输入样例#1:
4 1
1 2 1
1 3 1
1 4 1
输出样例#1:
3
输入样例#2:
4 1
1 2 3
2 3 1
3 4 2
输出样例#2:
1
说明
对于20%的数据,n <= 10
对于50%的数据,n <= 1000
对于100%的数据,n <= 100000
写在前面
lovny(YKJ):用树形DP呀?
Venus(LYT):还在做网络流?
。。。
没必要!完全没必要!这道题DFS就够了!
思路
很明显,要使一个叶子节点到不了祖先,有两种选择:
他的某个祖先到不了根节点
它父亲->它 删了
然后我们可以遍历一遍树。
DFS( x, fa ) = \(\Sigma\)min(DFS( i, x ) ( 存在边x->i), val(x->i) )
fa是为了避免搜到父亲节点。
若x为叶子节点,直接返回INF
也就是说,要么断开x->i让i到不了根节点,下面就不用再删边了,要么让i到的了根节点,在下面某处再断开。
他没说c的范围,保险起见开long long
代码很短。。。真的很短。。。
代码
#include<bits/stdc++.h>
using namespace std;
#define open(s) freopen( s".in", "r", stdin ), freopen( s".out", "w", stdout )
#define MAXN 100005
#define MAXM 200005
#define LL long long
int n, S;
int hd[MAXN], to[MAXM], nxt[MAXM], tot(1);
LL val[MAXM];
void Add( int x, int y, int z ){
	nxt[++tot] = hd[x]; hd[x] = tot; val[tot] = z; to[tot] = y;
	nxt[++tot] = hd[y]; hd[y] = tot; val[tot] = z; to[tot] = x;
}
LL DFS( int x, int fa ){
	LL ans(0); bool flg(0);
	for ( int i = hd[x]; i; i = nxt[i] )
		if ( to[i] != fa ) ans += min( DFS( to[i], x ), val[i] ), flg = 1;
	if ( !flg ) return LONG_LONG_MAX;
	return ans;
}
int main(){
	scanf( "%d%d", &n, &S );
	for ( int i = 1; i < n; ++i ){
		int x, y; LL z;
		scanf( "%d%d%lld", &x, &y, &z );
		Add( x, y, z );
	}
	printf( "%lld\n", DFS( S, S ) );
	return 0;
}
「洛谷P3931」 SAC E#1 - 一道难题 Tree的更多相关文章
- 「Luogu P3931」SAC E#1 - 一道难题 Tree 解题报告
		圆原题面 我环顾四周,发现大佬们的写法都好高端! 比较差劲的我,只能交上一份DFS的题解 思路: DFS(当然了,其他算法也行) 要想切断叶子节点到根节点的连接 就是在叶子节点和根节点之间砍掉一条边 ... 
- 「区间DP」「洛谷P1043」数字游戏
		「洛谷P1043」数字游戏 日后再写 代码 /*#!/bin/sh dir=$GEDIT_CURRENT_DOCUMENT_DIR name=$GEDIT_CURRENT_DOCUMENT_NAME ... 
- 「洛谷4197」「BZOJ3545」peak【线段树合并】
		题目链接 [洛谷] [BZOJ]没有权限号嘤嘤嘤.题号:3545 题解 窝不会克鲁斯卡尔重构树怎么办??? 可以离线乱搞. 我们将所有的操作全都存下来. 为了解决小于等于\(x\)的操作,那么我们按照 ... 
- 「洛谷3338」「ZJOI2014」力【FFT】
		题目链接 [BZOJ] [洛谷] 题解 首先我们需要对这个式子进行化简,否则对着这么大一坨东西只能暴力... \[F_i=\sum_{j<i} \frac{q_iq_j}{(i-j)^2}-\s ... 
- 「BZOJ2733」「洛谷3224」「HNOI2012」永无乡【线段树合并】
		题目链接 [洛谷] 题解 很明显是要用线段树合并的. 对于当前的每一个连通块都建立一个权值线段树. 权值线段树处理操作中的\(k\)大的问题. 如果需要合并,那么就线段树暴力合并,时间复杂度是\(nl ... 
- 「洛谷3870」「TJOI2009」开关【线段树】
		题目链接 [洛谷] 题解 来做一下水题来掩饰ZJOI2019考炸的心情QwQ. 很明显可以线段树. 维护两个值,\(Lazy\)懒标记表示当前区间是否需要翻转,\(s\)表示区间还有多少灯是亮着的. ... 
- 「洛谷5300」「GXOI/GZOI2019」与或和【单调栈+二进制转化】
		题目链接 [洛谷传送门] 题解 按位处理. 把每一位对应的图都处理出来 然后单调栈处理一下就好了. \(and\)操作处理全\(1\). \(or\)操作处理全\(0\). 代码 #include & ... 
- 「洛谷3469」「POI2008」BLO-Blockade【Tarjan求割点】
		题目链接 [洛谷传送门] 题解 很显然,当这个点不是割点的时候,答案是\(2*(n-1)\) 如果这个点是割点,那么答案就是两两被分开的联通分量之间求组合数. 代码 #include <bits ... 
- 「洛谷1884」「USACO12FEB」过度种植【离散化扫描线】
		题目链接 [洛谷传送门] 题解 矩阵面积的并模板.(请求洛谷加为模板题) 很明显是要离散化的. 我们将矩阵与\(x\)轴平行的两个线段取出来.并且将这两个端点的\(x1\)和\(x2\)进行离散化. ... 
随机推荐
- Python基础:常用函数
			1:enumerate enumerate(sequence, start=0) 该函数返回一个enumerate对象(一个迭代器).其中的sequence参数可以是序列.迭代器或者支持迭代的其他对象 ... 
- @bzoj - 4377@ [POI2015] Kurs szybkiego czytania
			目录 @description@ @solution@ @accepted code@ @details@ @description@ 给定 n, a, b, p,其中 n, a 互质.定义一个长度为 ... 
- laravel 5.5 登录验证码 captcha 引入
			https://blog.csdn.net/u013372487/article/details/79461730 前提: 开启Laravel 的用户认证功能 1.安装 Captcha 安装 Capt ... 
- Python进阶04函数的参数对应
			我们已经接触过函数(function)的参数(arguments)传递.当时我们根据位置,传递对应的参数.我们将接触更多的 参数传递方式. 回忆一下位置传递: def f(a,b,c): return ... 
- [luogu P2617] Dynamic Rankings 带修主席树
			带修改的主席树,其实这种,已经不能算作主席树了,因为这个没有维护可持久化的... 主席树直接带修改的话,由于这种数据结构是可持久化的,那么要相应改动,这个节点以后所有的主席树,这样单次修改,就达到n* ... 
- Tyvj-1338 QQ农场
			P1338 QQ农场 时间: 1000ms / 空间: 131072KiB / Java类名: Main 背景 Sandytea前段时间沉迷于QQ农场中……一天夜里,他梦见来到好友X的农场上…… 描述 ... 
- hdu 5734 Acperience(2016多校第二场)
			Acperience Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total ... 
- 给radio添加点击事件
			1.单独给每个radio添加点击事件 <fieldset id="form-gra-time"> <legend>请选择日期粒度:</legend&g ... 
- JS 动态表格
			表格 在script里面使用innerHTML获取标签体的内容,然后进行添加. 删除则是不断的获取父节点,利用父节点删除子节点. 在做这个的时候,要主要获取表格table的对象有两种方式,一是getE ... 
- jq制作tab栏
			<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ... 
