[NOIP2017 提高组] 宝藏

[NOIP2017 提高组] 宝藏

题目背景

NOIP2017 D2T2

题目描述

参与考古挖掘的小明得到了一份藏宝图,藏宝图上标出了 n n n 个深埋在地下的宝藏屋, 也给出了这 n n n 个宝藏屋之间可供开发的 m m m 条道路和它们的长度。

小明决心亲自前往挖掘所有宝藏屋中的宝藏。但是,每个宝藏屋距离地面都很远,也就是说,从地面打通一条到某个宝藏屋的道路是很困难的,而开发宝藏屋之间的道路则相对容易很多。

小明的决心感动了考古挖掘的赞助商,赞助商决定免费赞助他打通一条从地面到某个宝藏屋的通道,通往哪个宝藏屋则由小明来决定。

在此基础上,小明还需要考虑如何开凿宝藏屋之间的道路。已经开凿出的道路可以 任意通行不消耗代价。每开凿出一条新道路,小明就会与考古队一起挖掘出由该条道路所能到达的宝藏屋的宝藏。另外,小明不想开发无用道路,即两个已经被挖掘过的宝藏屋之间的道路无需再开发。

新开发一条道路的代价是 L × K \mathrm{L} \times \mathrm{K} L×K。其中 L L L 代表这条道路的长度, K K K 代表从赞助商帮你打通的宝藏屋到这条道路起点的宝藏屋所经过的宝藏屋的数量(包括赞助商帮你打通的宝藏屋和这条道路起点的宝藏屋) 。

请你编写程序为小明选定由赞助商打通的宝藏屋和之后开凿的道路,使得工程总代价最小,并输出这个最小值。

输入格式

第一行两个用空格分离的正整数 n , m n,m n,m,代表宝藏屋的个数和道路数。

接下来 m m m 行,每行三个用空格分离的正整数,分别是由一条道路连接的两个宝藏屋的编号(编号为 1 − n 1-n 1−n),和这条道路的长度 v v v。

输出格式

一个正整数,表示最小的总代价。

样例 #1

样例输入 #1

复制代码
4 5 
1 2 1 
1 3 3 
1 4 1 
2 3 4 
3 4 1

样例输出 #1

复制代码
4

样例 #2

样例输入 #2

复制代码
4 5 
1 2 1 
1 3 3 
1 4 1 
2 3 4 
3 4 2

样例输出 #2

复制代码
5

提示

【样例解释 1 1 1】

小明选定让赞助商打通了 1 1 1 号宝藏屋。小明开发了道路 1 → 2 1 \to 2 1→2,挖掘了 2 2 2 号宝藏。开发了道路 1 → 4 1 \to 4 1→4,挖掘了 4 4 4 号宝藏。还开发了道路 4 → 3 4 \to 3 4→3,挖掘了 3 3 3 号宝藏。

工程总代价为 1 \\times 1 + 1 \\times 1 + 1 \\times 2 = 4

【样例解释 2 2 2】

小明选定让赞助商打通了 1 1 1 号宝藏屋。小明开发了道路 1 → 2 1 \to 2 1→2,挖掘了 2 2 2 号宝藏。开发了道路 1 → 3 1 \to 3 1→3,挖掘了 3 3 3 号宝藏。还开发了道路 1 → 4 1 \to 4 1→4,挖掘了 4 4 4 号宝藏。

工程总代价为 1 × 1 + 3 × 1 + 1 × 1 = 5 1 \times 1 + 3 \times 1 + 1 \times 1 = 5 1×1+3×1+1×1=5。

【数据规模与约定】

对于 20% 的数据: 保证输入是一棵树, 1 ≤ n ≤ 8 1 \le n \le 8 1≤n≤8, v ≤ 5 × 1 0 3 v \le 5\times 10^3 v≤5×103 且所有的 v v v 都相等。

对于 40 % 40\% 40% 的数据: 1 ≤ n ≤ 8 1 \le n \le 8 1≤n≤8, 0 ≤ m ≤ 1 0 3 0 \le m \le 10^3 0≤m≤103, v ≤ 5 × 1 0 3 v \le 5\times 10^3 v≤5×103 且所有的 v v v 都相等。

对于 70% 的数据: 1 ≤ n ≤ 8 1 \le n \le 8 1≤n≤8, 0 ≤ m ≤ 1 0 3 0 \le m \le 10^3 0≤m≤103, v ≤ 5 × 1 0 3 v \le 5\times 10^3 v≤5×103。

对于 100% 的数据: 1 ≤ n ≤ 12 1 \le n \le 12 1≤n≤12, 0 ≤ m ≤ 1 0 3 0 \le m \le 10^3 0≤m≤103, v ≤ 5 × 1 0 5 v \le 5\times 10^5 v≤5×105。


upd 2022.7.27 \text{upd 2022.7.27} upd 2022.7.27:新增加 50 50 50 组 Hack 数据。

相关推荐
你们补药再卷啦28 分钟前
人工智能算法概览
人工智能·算法
cnxy18833 分钟前
围棋对弈Python程序开发完整指南:步骤3 - 气(Liberties)的计算算法设计
python·算法·深度优先
AndrewHZ43 分钟前
【图像处理基石】什么是光栅化?
图像处理·人工智能·算法·计算机视觉·3d·图形渲染·光栅化
小白菜又菜1 小时前
Leetcode 944. Delete Columns to Make Sorted
算法·leetcode
我找到地球的支点啦1 小时前
Matlab系列(006) 一利用matlab保存txt文件和读取txt文件
开发语言·算法·matlab
Dev7z2 小时前
基于Matlab实现GRACE卫星重力数据的全球水储量变化估算与分析
人工智能·算法·matlab
爱喝热水的呀哈喽2 小时前
11题目汇总
算法
三斗米3 小时前
Transformer入门:一文读懂《Attention Is All You Need》
算法·架构
Swift社区3 小时前
LeetCode 458 - 可怜的小猪
算法·leetcode·职场和发展
AI科技星3 小时前
宇宙的像素:真空中一点如何编码无限星光
数据结构·人工智能·算法·机器学习·重构