Description

\(n\) 个点,有各自的高度。

\(m\) 条道路,有各自的长度,每条可连接两个点。

规定只能从高点走向低点,可以回到原来的某个位置走不同的道路。

求在行走道路尽量短的情况下到达点的数量尽量多

Solution

就是最小生成树加个高度判断

思路:走一边图,搜索把从一点开始能走到的所有点放到一个新图里,然后判断高低走最小生成树

搜索的过程是类似于 \(Dijkstra\) 的思想,用 \(STL\) 就好了

注意手写 \(cmp\) 的时候把高度放在第一条件,距离放在第二条件

其他并没有什么很难的操作

Code

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<cstdlib>
#include<queue>
#define maxn 2000100 using namespace std; inline int read(){
int s=0,w=1;
char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}
while(ch>='0'&&ch<='9') s=s*10+ch-'0',ch=getchar();
return s*w;
}
//======================================================================================
long long n,m,h[maxn],u[maxn],v[maxn],w,cnt;
long long head[maxn],tot1,tot2,fa[maxn],ans;
bool vis[maxn]; struct edge{
int to,fr,nxt,dis;
}e1[maxn*2],e2[maxn*2]; void add1(int fr,int to,int dis){
e1[++tot1].to=to;
e1[tot1].dis=dis;
e1[tot1].fr=fr;
e1[tot1].nxt=head[fr];
head[fr]=tot1;
} void add2(int fr,int to,int dis){
e2[++tot2].to=to;
e2[tot2].dis=dis;
e2[tot2].fr=fr;
} int esort(edge a,edge b){
if(h[a.to]==h[b.to]) return (a.dis<b.dis);
else return (h[a.to]>h[b.to]);
}
//======================================================================================= int Get_Father(int x){
if(fa[x]==x) return x;
return fa[x]=Get_Father(fa[x]);
} void hb(int x,int y){
x=Get_Father(x);
y=Get_Father(y);
if(x!=y) fa[y]=x;
} bool pd(int x,int y){
x=Get_Father(x);
y=Get_Father(y);
if(x==y) return true;
return false;
} void bfs(int x){
queue<int> q;
q.push(x);
vis[1]=1;
while(!q.empty()){
int xx=q.front();
q.pop();
for(int i=head[xx];i;i=e1[i].nxt){
int to=e1[i].to;
add2(e1[i].fr,e1[i].to,e1[i].dis);
if(!vis[to]){
q.push(to);
vis[to]=1;
cnt++;
}
}
}
} int main(){
n=read();m=read();
for(int i=1;i<=n;i++){
h[i]=read();
fa[i]=i;
}
for(int i=1;i<=m;i++){
u[i]=read(),v[i]=read(),w=read();
if(h[u[i]]>=h[v[i]]) add1(u[i],v[i],w);
if(h[u[i]]<=h[v[i]]) add1(v[i],u[i],w);
}
bfs(1);
// add(u[i],v[i],w);
sort(e2+1,e2+tot2+1,esort);
// for(int i=1;i<=m;i++) cout<<e[i].fr<<" "<<e[i].to<<" "<<e[i].dis<<endl;
for(int i=1;i<=tot2;i++){
if(pd(e2[i].fr,e2[i].to)) continue;
hb(e2[i].fr,e2[i].to);
ans+=e2[i].dis;
} printf("%lld %lld",cnt+1,ans);
return 0;
}

洛谷P2573的更多相关文章

  1. 洛谷1640 bzoj1854游戏 匈牙利就是又短又快

    bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...

  2. 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.

    没有上司的舞会  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond       题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...

  3. 洛谷P1108 低价购买[DP | LIS方案数]

    题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买:再低价购买”.每次你购买一支股票,你必须用低于你上次购买它的价格购买它 ...

  4. 洛谷 P2701 [USACO5.3]巨大的牛棚Big Barn Label:二维数组前缀和 你够了 这次我用DP

    题目背景 (USACO 5.3.4) 题目描述 农夫约翰想要在他的正方形农场上建造一座正方形大牛棚.他讨厌在他的农场中砍树,想找一个能够让他在空旷无树的地方修建牛棚的地方.我们假定,他的农场划分成 N ...

  5. 洛谷P1710 地铁涨价

    P1710 地铁涨价 51通过 339提交 题目提供者洛谷OnlineJudge 标签O2优化云端评测2 难度提高+/省选- 提交  讨论  题解 最新讨论 求教:为什么只有40分 数组大小一定要开够 ...

  6. 洛谷P1371 NOI元丹

    P1371 NOI元丹 71通过 394提交 题目提供者洛谷OnlineJudge 标签云端评测 难度普及/提高- 提交  讨论  题解 最新讨论 我觉得不需要讨论O long long 不够 没有取 ...

  7. 洛谷P1538迎春舞会之数字舞蹈

    题目背景 HNSDFZ的同学们为了庆祝春节,准备排练一场舞会. 题目描述 在越来越讲究合作的时代,人们注意的更多的不是个人物的舞姿,而是集体的排列. 为了配合每年的倒计时,同学们决定排出——“数字舞蹈 ...

  8. 洛谷八月月赛Round1凄惨记

    个人背景: 上午9:30放学,然后因为学校举办读书工程跟同学去书城选书,中午回来开始打比赛,下午又回老家,中间抽出一点时间调代码,回家已经8:50了 也许是7月月赛时“连蒙带骗”AK的太幸运然而因同学 ...

  9. 洛谷 P1379 八数码难题 Label:判重&&bfs

    特别声明:紫书上抄来的代码,详见P198 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给 ...

随机推荐

  1. [LeetCode]Minimum Moves to Equal Array Elements1,2

    1.将每次n-1个数+1,转化为每次最大的数-1 public int minMoves(int[] nums) { /* 看了看答案 ,很巧妙,最后的结果肯定是把数组元素都加到一个相同的值, 也就是 ...

  2. WebService的简单Demo

    看到招聘要求要会WebService.就百度看看是如何实现的. 测试了一下.发现使用webservice开发方法,好像方便了不少.服务端开发者只需要关注服务端就可以了. Demo结构 IWebServ ...

  3. Thread通信与唤醒笔记1

    synchronized if判断标记,只有一次,会导致不该信息的线程运行了,出现了数据错误的情况 while判断标记,解决了线程获取执行权之后,是否要运行! notify 只能唤醒一个任意线程,如果 ...

  4. js相关语法知识

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

  5. 一文掌握XSS

    目录 XSS跨站脚本攻击 1.什么叫跨站脚本攻击? 2.XSS跨站脚本攻击的原理 3.XSS跨站脚本攻击的目的是什么? 4.XSS跨站脚本攻击出现的原因 5.XSS跨站脚本攻击的条件 1.有输入有输出 ...

  6. 解决MySQL Workbench导出低版本MySQL时报错Unknown table ‘column_statistics’ in information_schema的问题

    在使用高版本MySQL Workbench或MySQL 8.0+版本提供的mysqldump.exe(实际高版本的MySQL Workbench使用的也是高版本的mysqldump.exe)来导出低于 ...

  7. js--获取滚动条位置,并实现页面滑动到锚点位置

    前言 这篇来记录下最近工作中遇到的一个问题,在app原生和前端h5混合开发的过程中,其中一个页面是选择城市列表的页面,类似于美团饿了么城市选择,银行app中银行列表选择,通讯录中快速定位到联系人选择的 ...

  8. PAT天梯赛练习 L3-004 肿瘤诊断 (30分) 三维BFS

    题目分析: 可能是我的理解能力比较差,在读题的时候一直以为所有的切片是可以排列组合的,并不是按照输入顺序就定死的,那么这题就变得十分的复杂啦~~~~~,查看的题解之后发现所有的切片并没有所谓的自由组合 ...

  9. Jenkins Android APP 持续集成体系建设二—自动部署、执行测试任务,关联打包任务

    经过上一遍博客我们知道了怎么使用Jenkins自动打包,但打完包之后,我们还需要对新包进行回归测试,确定新包有没有问题,然后才能发布包,那么,话不多说,我们先来新建个自动化回归测试任务 新包自动化回归 ...

  10. DG主备切换遇到not allwod或者RESOLVABLE GAP解决办法

    今天做switchover,环境是11.2.0.3+OEL5.7,开始时主备库状态都是正常的,符合直接切换条件: 主库: SQL> select open_mode,database_role, ...