P2573 [SCOI2012]滑雪 题解
下午花了三个小时肝这道题,心态差点爆炸!
下面是分析:
1 题目要求:
2 求最小生成树
3 但是
4 - a是从1号点开始的 --> 如果以后的某个点比一号高,则不可能到达
5 - a只能从高往低处滑
6 - 可能某两个景点没有轨道连接 -->没有处在一个联通快里?
7
8 生成树的要求:
9 - 树根高度最大
10 - 子节点的高度必须比父亲结点小
11 - 边权和尽可能小
12
13 自己造的样例:
14 输入:
15 4 4
16 4 2 3 1
17 1 2 3
18 2 3 2
19 2 4 4
20 3 4 1
21
22 输出:
23 3 7
从题解上爬的Solotion:
1 为保证我们只会由高到低,我们就只建立由高向低的单向边即可。
2
3 对于建立出来的图A,由1点开始宽搜,将扩展到的点和边加入一个新图B,
4 所有扩展到的点便是能到达的最多点。
5
6 我们再在这个新图上跑Kruskal求最小生成树,求得最短距离。
7
8 对于排序部分,为保证有尽可能多的点在最小生成树里,
9 我们按终点的高度为第一关键字从大到小排序,边长为第二关键字从小到大排序;
10
11 这样就能保证拓展的点最多,进而再用最小生成树求最短距离。
最终AC代码:
1 /*
2 Work By:Suzt_ilymtics
3 */
4 #include<iostream>
5 #include<cstdio>
6 #include<algorithm>
7 #include<queue>
8 using namespace std;
9 const int MAXN=1e5+5;
10 const int MAXM=1e6+6;
11 struct edge{
12 int from,to,nxt;
13 long long w;
14 }e_a[MAXM << 1],e_b[MAXM << 1];
15 int head_a[MAXN],num_edge_a;
16 int num_edge_b;
17 int n,m,cnt;
18 long long ans;
19 int h[MAXN],f[MAXN];
20 bool vis[MAXN];
21 queue<int> q;
22
23 int find(int x) {return f[x] == x ? x : f[x]=find(f[x]);}
24
25 bool cmp(edge x,edge y){return h[x.to] == h[y.to] ? x.w < y.w : h[x.to] > h[y.to];}
26
27 void add_a(int from,int to,int w){
28 e_a[++num_edge_a].from = from;
29 e_a[num_edge_a].to = to;
30 e_a[num_edge_a].w = w;
31 e_a[num_edge_a].nxt = head_a[from];
32 head_a[from] = num_edge_a;
33 }
34
35 void add_b(int from,int to,int w){
36 e_b[++num_edge_b].from = from;
37 e_b[num_edge_b].to = to;
38 e_b[num_edge_b].w = w;
39 }
40
41 void bfs(int x){
42 q.push(x);vis[1]=1;
43 while(!q.empty()){
44 int t=q.front(); q.pop();
45 for(int i=head_a[t];i;i=e_a[i].nxt){
46 add_b(e_a[i].from,e_a[i].to,e_a[i].w);
47 if(!vis[e_a[i].to]){
48 vis[e_a[i].to]=1;
49 q.push(e_a[i].to);
50 cnt++;
51 }
52 }
53 }
54 }
55
56 void kls(){
57 for(int i=1;i<=num_edge_b;++i){
58 int uf=find(e_b[i].from),vf=find(e_b[i].to);
59 if( uf == vf ) continue;
60 else{
61 f[uf] = vf;
62 ans+=e_b[i].w;
63 }
64 }
65 }
66
67 int main()
68 {
69 scanf("%d%d",&n,&m);
70 for(int i=1;i<=n;++i){
71 scanf("%d",&h[i]),f[i]=i;
72 }
73 for(int i=1,u,v,w;i<=m;++i){
74 scanf("%d%d%d",&u,&v,&w);
75 if(h[u]>=h[v]) add_a(u,v,w);
76 if(h[u]<=h[v]) add_a(v,u,w);
77 }
78 bfs(1);
79 sort(e_b+1,e_b+num_edge_b+1,cmp);
80 kls();
81 printf("%d %lld",cnt+1,ans);
82 return 0;
83 }
The end
(这篇文章终于能看了点)
P2573 [SCOI2012]滑雪 题解的更多相关文章
- P2573 [SCOI2012]滑雪
题目描述 a180285非常喜欢滑雪.他来到一座雪山,这里分布着 M 条供滑行的轨道和 N 个轨道之间的交点(同时也是景点),而且每个景点都有一编号 i ( 1≤i≤N )和一高度 Hi.a18028 ...
- BZOJ 2753 [SCOI2012] 滑雪和时间胶囊 最小生成树
题目链接: 题目 2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec Memory Limit: 128 MB 问题描述 a180285非常喜欢滑雪.他来到一座雪山, ...
- Bzoj2753 [SCOI2012]滑雪与时间胶囊
2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec Memory Limit: 128 MBSubmit: 2282 Solved: 796 Descriptio ...
- Code[VS] 2152 滑雪题解
Code[VS] 2152 滑雪题解 题目描述 Description trs喜欢滑雪.他来到了一个滑雪场,这个滑雪场是一个矩形,为了简便,我们用r行c列的矩阵来表示每块地形.为了得到更快的速度,滑行 ...
- bzoj 2753: [SCOI2012]滑雪与时间胶囊 -- 最小生成树
2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec Memory Limit: 128 MB Description a180285非常喜欢滑雪.他来到一座雪山,这 ...
- 【BZOJ 2753】 2753: [SCOI2012]滑雪与时间胶囊 (分层最小树形图,MST)
2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec Memory Limit: 128 MBSubmit: 2457 Solved: 859 Descriptio ...
- BZOJ2753 SCOI2012 滑雪与时间胶囊 【最小生成树】*
BZOJ2753 SCOI2012 滑雪与时间胶囊 Description a180285非常喜欢滑雪.他来到一座雪山,这里分布着M条供滑行的轨道和N个轨道之间的交点(同时也是景点),而且每个景点都有 ...
- 2753: [SCOI2012]滑雪与时间胶囊
2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec Memory Limit: 128 MBSubmit: 2633 Solved: 910 Descriptio ...
- bzoj 2753: [SCOI2012] 滑雪与时间胶囊 Label:MST
题目描述 a180285非常喜欢滑雪.他来到一座雪山,这里分布着M条供滑行的轨道和N个轨道之间的交点(同时也是景点),而且每个景点都有一编号i(1<=i<=N)和一高度Hi.a180285 ...
随机推荐
- Deep Neural Networks for YouTube Recommendations YouTube的经典推荐框架
https://zhuanlan.zhihu.com/p/52169807 王喆大佬的讲解
- 页面中嵌套iframe,微信浏览器长按二维码识别不了
问题:在微信浏览器内,页面中嵌套iframe,iframe中用户触发事件后有个弹框会显示二维码,用户长按二维码可以识别并跳转.尝试了一下,安卓是正常的,但是ios是识别不了的. 解决过程: 1.这里客 ...
- C# 打开Excel文件
方法一:(调用Excel的COM组件) 在项目中打开Add Reference对话框,选择COM栏,之后在COM列表中找到"Microsoft Excel 11.0 Object ...
- python-scrapy框架爬取某瓣电视剧信息--异步加载页面
前期准备,首先要有python环境+scrapy环境+pycharm环境 一.建立爬虫所需的环境,在命令行输入: scrapy startproject doubantv #命名自定义就好 会生成一个 ...
- Base 128 Varints 编码(压缩算法)
Base 128 Varint可以说是一种编码方式,也可以说是一种压缩算法.这种压缩算法是用来压缩数字的传输的,压缩的依据是基于一个现实:越小的数字,越经常使用 我们来看看一个例子: 如果我们要网络传 ...
- Maven的安装跟配置(最全)
一.去官网下载maven 官网地址: https://maven.apache.org/ 点击下载apache-maven-3.6.3-bin.zip 下载完成后解压即可. 二.配置环境变量 在我们的 ...
- vue项目中的路由守卫
路由守卫的意义就相当于一个保安一样,作用很大,在实际的项目中运用也是不少,也就是当客户在登陆自己账号的时候,有可能存在客户有啥事的时候,自己后台或者pc的关闭全部浏览器,没有点击退出登录,或者在退出登 ...
- linux根文件系统 /etc/resolv.conf 文件详解
Linux根文件系统/etc/resolv.conf文件,它是DNS客户机配置文件,用于设置DNS服务器的IP地址及DNS域名,还包含了主机的域名搜索顺序.该文件是由域名解析器(resolver,以恶 ...
- MYSQL 字符集设置(终端的字符集)
每次利用终端 创建数据库或者创建表的时候,字符集都是latin1(不指定字符集的时候)如下: 查看当前数据库的字符集 character_set_client:客户端请求数据的字符集character ...
- 安装蓝鲸paas社区版
安装蓝鲸paas社区版http://docs.bk.tencent.com/bkce_install_guide/setup/get_ready.html#hostssystemctl stop fi ...