【BZOJ 2753 滑雪与时间胶囊】
Time Limit: 50 Sec Memory Limit: 128 MB
Submit: 2843 Solved: 993
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
3 3
3 2 1
1 2 1
2 3 1
1 3 10
Sample Output
HINT
【数据范围】
对于30%的数据,保证 1<=N<=2000
对于100%的数据,保证 1<=N<=100000
对于所有的数据,保证 1<=M<=1000000,1<=Hi<=1000000000,1<=Ki<=1000000000。
Source
【题解】
①第一问可以直接bfs解决;
②可以想到如果只考虑可以到的点就和最小生成树类似,但是是有向的,直接kruskal或prim会错
(因为MST只在无向图上成立);改进一下:
③由于有高度,考虑分层即可(跑最小生成树是把高度作为第一关键字,长度作为第二关键字),优先高的,就可以处理有向的问题。
/*3 3
3 2 1
1 2 1
2 3 1
1 3 10
这个故事告诉我们证明是很重要的;
看来我要好好学数学,端正态度;
MST成立的条件是环
记得清华来的第二个学长说过:
“如果你不清楚是不是对的,就尝试去证明,到哪里证不出来了就是问题。”
*/
#include <cstdio>
#include <iostream>
#include <cstring>
#include <algorithm>
#include <queue>
#include <vector>
#include <ctime>
#include <cmath>
#define inf 0x3f3f3f3f
#define ll long long
#define N 100010
#define M 1000100
#define mem(f,a) memset(f,a,sizeof(f))
#define Run(i,l,r) for(int i=l;i<=r;i++)
#define Don(i,l,r) for(int i=l;i>=r;i--)
#define Eun(i,u,E,head) for(int i=head[u],v=E[i].v;i!=-1;i=E[i].next,v=E[i].v)
using namespace std;
int n,m;
int H[N],vis[N],head[N],k,fa[N],dis[N];
struct Edge{
int u,v,w,next;
bool operator <(const Edge a)const{
return (H[a.v]==H[v])? a.w>w : H[a.v]<H[v];
}
}E[*M];
queue<int>Q;
ll cnt,ans;
void adde(int u,int v,int w)
{ E[k]=(Edge){u,v,w,head[u]};
head[u]=k++;
}
void Bfs()
{ Q.push(); vis[]=; cnt=;
while (!Q.empty()){
int u=Q.front(); Q.pop();
Eun(i,u,E,head)
if (!vis[v]) cnt++,vis[v]=,Q.push(v);
}
}
int find(int x)
{ if (fa[x]==x) return x;
else return fa[x]=find(fa[x]);
}
void Kruskal()
{ sort(E,E+k);
Run(i,,n) fa[i]=i;
Run(i,,k-){
if (!vis[E[i].u]||!vis[E[i].v]) continue;
int fx=find(E[i].u),fy=find(E[i].v);
if (fx!=fy) ans+=E[i].w,fa[fx]=fy;
}
}
int main()
{ //freopen("ski.in","r",stdin);
//freopen("ski.out","w",stdout);
scanf("%d%d",&n,&m);
Run(i,,n){
scanf("%d",&H[i]);
}
int u,v,w; mem(head,-);
Run(i,,m){
scanf("%d%d%d",&u,&v,&w);
if (H[u]>=H[v]) adde(u,v,w);
if (H[u]<=H[v]) adde(v,u,w);
}
Bfs();
Kruskal();
printf("%lld %lld",cnt,ans);
return ;
}//by tkys_Austin;
【BZOJ 2753 滑雪与时间胶囊】的更多相关文章
- CDOJ 42/BZOJ 2753 滑雪与时间胶囊 kruskal
2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec Memory Limit: 128 MBSubmit: 1376 Solved: 487[Submit][St ...
- 【BZOJ】【2753】【SCOI2012】滑雪与时间胶囊
Kruskal/最小树形图 然而蒟蒻并不会做这题>_> 本来以为是有向图最小生成树,即最小树形图,但这数据范围有点…… 膜拜了zyf的题解:http://www.cnblogs.com/z ...
- BZOJ 2753 [SCOI2012] 滑雪和时间胶囊 最小生成树
题目链接: 题目 2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec Memory Limit: 128 MB 问题描述 a180285非常喜欢滑雪.他来到一座雪山, ...
- 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 ...
- 【最小树形图(奇怪的kruskal)】【SCOI 2012】【bzoj 2753】滑雪与时间胶囊
2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec Memory Limit: 128 MB Submit: 1621 Solved: 570 Description ...
- 2753: [SCOI2012]滑雪与时间胶囊
2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec Memory Limit: 128 MBSubmit: 2633 Solved: 910 Descriptio ...
- Bzoj2753 [SCOI2012]滑雪与时间胶囊
2753: [SCOI2012]滑雪与时间胶囊 Time Limit: 50 Sec Memory Limit: 128 MBSubmit: 2282 Solved: 796 Descriptio ...
- BZOJ2753 SCOI2012 滑雪与时间胶囊 【最小生成树】*
BZOJ2753 SCOI2012 滑雪与时间胶囊 Description a180285非常喜欢滑雪.他来到一座雪山,这里分布着M条供滑行的轨道和N个轨道之间的交点(同时也是景点),而且每个景点都有 ...
随机推荐
- redhat6.5安装oracle 11g
1.修改操作系统核心参数 在Root用户下执行以下步骤: 1)修改用户的SHELL的限制,修改/etc/security/limits.conf文件 输入命令:vi /etc/security/lim ...
- Vee-validate学习
Vee-validate使用方法 首先引入 <script src="https://cdn.bootcss.com/vee-validate/2.0.9/vee-validate.j ...
- CONCATENATE命令(文字列の結合)
CONCATENATE命令とは文字列の結合を行う命令である.文字列を扱うChar, Numeric, Dats, Time, Stringの変数で使用する事が可能だ.単純に文字列の結合のみを行う方法. ...
- python2.7练习小例子(二十三)
23):题目:求1+2!+3!+...+20!的和. 程序分析:此程序只是把累加变成了累乘. #!/usr/bin/python # -*- coding: UTF-8 -*- n = ...
- 10+ Best Responsive HTML5 AngularJS Templates
http://www.responsivemiracle.com/collective/best-responsive-html5-angularjs-templates/
- css匹配规则及性能
一.CSS是如何匹配样式的 样式系统从最右边的选择符开始向左进行匹配规则.只要当前选择符的左边还有其他选择符,样式系统就会继续向左移动,直到找到和规则匹配的元素,或者因为不匹配而退出. 二.CSS选择 ...
- 自动化测试学习之路--java String、StringBuilder
Java中的String和StringBuilder类: 1.String对象是不可变的.每一个看起来修改了String值的方法,实际上都是创建了全新的String对象.代码示例如下: String ...
- python QQ邮箱自动发送邮件
于初学者来讲在写发送邮件代码时常见的错误有SMTPAuthenticationError535,有点懵逼,检查用户名,密码正确就是报错, 想当年笔者也是这么过来的,现在就给大家分享一下个人经验: 一, ...
- 给移动硬盘安装rhel7
本机是win8.1的系统,但不想给电脑装双系统,所以想给移动硬盘里安装rhel7移动硬盘是750G的在网上搜了很多方法,我采取了两个方法:方法一.1.取一个U盘,用软碟通把rhel7的iso文件写进了 ...
- c# mysql blob数据类型
1.采用stream流形式写入: #region 数据流转换成blob类型数据写入数据库 static public bool StreamToBlob(ref Stream stream, Odbc ...