下午花了三个小时肝这道题,心态差点爆炸!

下面是分析:

 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]滑雪 题解的更多相关文章

  1. P2573 [SCOI2012]滑雪

    题目描述 a180285非常喜欢滑雪.他来到一座雪山,这里分布着 M 条供滑行的轨道和 N 个轨道之间的交点(同时也是景点),而且每个景点都有一编号 i ( 1≤i≤N )和一高度 Hi.a18028 ...

  2. BZOJ 2753 [SCOI2012] 滑雪和时间胶囊 最小生成树

    题目链接: 题目 2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec Memory Limit: 128 MB 问题描述 a180285非常喜欢滑雪.他来到一座雪山, ...

  3. Bzoj2753 [SCOI2012]滑雪与时间胶囊

    2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 2282  Solved: 796 Descriptio ...

  4. Code[VS] 2152 滑雪题解

    Code[VS] 2152 滑雪题解 题目描述 Description trs喜欢滑雪.他来到了一个滑雪场,这个滑雪场是一个矩形,为了简便,我们用r行c列的矩阵来表示每块地形.为了得到更快的速度,滑行 ...

  5. bzoj 2753: [SCOI2012]滑雪与时间胶囊 -- 最小生成树

    2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec  Memory Limit: 128 MB Description a180285非常喜欢滑雪.他来到一座雪山,这 ...

  6. 【BZOJ 2753】 2753: [SCOI2012]滑雪与时间胶囊 (分层最小树形图,MST)

    2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 2457  Solved: 859 Descriptio ...

  7. BZOJ2753 SCOI2012 滑雪与时间胶囊 【最小生成树】*

    BZOJ2753 SCOI2012 滑雪与时间胶囊 Description a180285非常喜欢滑雪.他来到一座雪山,这里分布着M条供滑行的轨道和N个轨道之间的交点(同时也是景点),而且每个景点都有 ...

  8. 2753: [SCOI2012]滑雪与时间胶囊

    2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 2633  Solved: 910 Descriptio ...

  9. bzoj 2753: [SCOI2012] 滑雪与时间胶囊 Label:MST

    题目描述 a180285非常喜欢滑雪.他来到一座雪山,这里分布着M条供滑行的轨道和N个轨道之间的交点(同时也是景点),而且每个景点都有一编号i(1<=i<=N)和一高度Hi.a180285 ...

随机推荐

  1. element-ui 表单 v-if 不能验证问题

    element-ui 表单v-if 很多人会遇到无法验证的问题,网上很多是在el-form-item标签前加一个div然后把v-if拿到div上去像这样 <div v-if="addc ...

  2. 多个table表不同数据切换 easyui中

    未处理  有效   无效  切换显示 1.加载页面时将 未处理 ,无效  有效的数据分别查到,给对应的table赋值 <%--easyui 的 tab标签栏--%><div id=& ...

  3. 支付业务优化else if 代码

    背景 最近在做项目的时候,需要接入支付.由于接入第三方支付而且还不知止一家,需要接入很多家.比如说支付宝.微信.富友支付等.每家支付都一个回调.现如今的代码,根据不同的第三方支付一大堆else if判 ...

  4. BOM主数据-用ECN实现可变BOM

    用ECN变更号实现可变BOM:通过ECN变更号的参数类型来实现BOM的可变配置. 物料编号:2104 (1)首先BOM的父项物料主数据<基本数据1>必须设置栏位"参数有效值&qu ...

  5. 设置Safari禁止访问某个网站

    经过调查有三种方法可以做到:1,创立新的登录账户,然后进行家长控制:2,安装第三方的应用软件Self Control:3,其他方式 推荐大家使用下面的这个方式:三步即可 1:打开访达(Finder), ...

  6. js相关语法知识

    alert(); 页面弹窗 <input plactholder="请输入密码"/>(隐藏字体效果)js对数据类型不敏感,与Java相似1.js变量定义符:var2.j ...

  7. TCP实现网络通讯

    Tcp server的流程:1.创建套接字:2.bind绑定ip和port3.listen使套接字变为可以被动链接:4.accept等待客户端的链接(返回为服务器分配的客户端的句柄和地址)5.reci ...

  8. @component的作用详细介绍

    最近项目要采用spring boot在学习的spring boot 的过程中第一次见到@component注解,特意在网上搜索下,摘录在此方便日后查阅. 1.@controller 控制器(注入服务) ...

  9. Kubernetes官方java客户端之四:内部应用

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  10. Linux下docker中安装宝塔面板教程

    本人云服务器,装的cent os7.6,在cent os7.6已装了docker,没装的可以借鉴 https://www.cnblogs.com/xiaoyige/p/12673076.html 1. ...