牛客周赛52--E小红的图上加边(联通块)

链接:登录—专业IT笔试面试备考平台_牛客网
来源:牛客网
 

题目描述

          \,\,\,\,\,\,\,\,\,\,小红有一张 nnn 个点 mmm 条边的无向图,每个节点的权值是 aia_iai​。
          \,\,\,\,\,\,\,\,\,\,现在小红希望加边把这个图连成连通图,每次连接的代价是新形成的联通块的最大元素值,小红想知道最小需要消耗多少代价可以把这个图连成连通的。

输入描述:

          \,\,\,\,\,\,\,\,\,\,第一行输入两个整数nnn 和 m (1≤n≤105;m\ (1 \leq n \leq 10^5;m (1≤n≤105; 0≤m≤105)0 \leq m \leq 10^5)0≤m≤105) 表示点数和边数。\,\,\,\,\,\,\,\,\,\,第二行输入 nnn 个整数 a1,a2,…,an (1≤ai≤109)a_1,a_2,\dots,a_n\ (1 \leq a_i \leq 10^9)a1​,a2​,…,an​ (1≤ai​≤109) 表示每个节点的权值。\,\,\,\,\,\,\,\,\,\,接下来 mmm 行,第 iii 行输入两个整数 uiu_iui​ 和 vi (1≤ui,vi≤n)v_i\ (1 \leq u_i,v_i \leq n)vi​ (1≤ui​,vi​≤n) 表示无向图上第 iii 条边连接节点 uiu_iui​ 和 viv_ivi​ ,保证没有重边。

输出描述:

 

          \,\,\,\,\,\,\,\,\,\,在一行上输出一个整数,表示最小需要消耗的代价。

示例1

输入

复制5 3 1 2 3 4 5 1 2 2 3 1 3

5 3
1 2 3 4 5
1 2
2 3
1 3

输出

复制9

9

说明

先加上 (1,4)(1, 4)(1,4) 这条边,代价是 444,然后加上 (1,5)(1, 5)(1,5) 这条边,代价是 555,总代价是 999。

做法

把每个联通块的最大值维护出来,然后最大值总和减去最小的那个即可。求连通块可以用bfs或者并查集。

1.bfs

#include<bits/stdc++.h>
using namespace std;
int n,m;
long long a[100010];
int vis[100010],head[100010];
long long ans;
int tot;
struct ty{int t,next;
}edge[200010];
void addedge(int x,int y){edge[++tot].t=y;edge[tot].next=head[x];head[x]=tot;
}
queue<int> q;
void bfs(int x){if(vis[x]) return ;q.push(x);while(!q.empty()){int xx=q.front();q.pop();if(vis[xx]) continue;vis[xx]=x;for(int i=head[xx];i!=-1;i=edge[i].next){if(vis[edge[i].t]) continue;q.push(edge[i].t);}}
}
int main(){memset(head,-1,sizeof(head));scanf("%d%d",&n,&m);for(int i=1;i<=n;i++) scanf("%lld",&a[i]);for(int i=1;i<=m;i++){int u,v;scanf("%d%d",&u,&v);addedge(u,v);addedge(v,u);}for(int i=1;i<=n;i++){bfs(i);}map<int,long long> mp;for(int i=1;i<=n;i++){mp[vis[i]]=max(mp[vis[i]],a[i]);}vector<long long> v;for(map<int,long long>::iterator it=mp.begin();it!=mp.end();it++){v.push_back(it->second);}sort(v.begin(),v.end());for(int i=1;i<v.size();i++) ans+=v[i];cout<<ans;
}

2.并查集

#include<bits/stdc++.h>
using namespace std;
int n,m;
int a[100010];
int fa[100010];
int getfa(int x){if(fa[x]==x) return x;return fa[x]=getfa(fa[x]); 
}
void setfa(int x,int y){fa[getfa(x)]=getfa(y);
}
long long ans;
int main(){scanf("%d%d",&n,&m);for(int i=1;i<=n;i++) scanf("%d",&a[i]);for(int i=1;i<=n;i++) fa[i]=i;for(int i=1;i<=m;i++){int u,v;scanf("%d%d",&u,&v);setfa(u,v);}map<int,int> mp;for(int i=1;i<=n;i++){mp[getfa(i)]=max(mp[getfa(i)],a[i]);}vector<int> v;for(int i=1;i<=n;i++){if(getfa(i)==i) v.push_back(mp[i]);}sort(v.begin(),v.end());for(int i=1;i<v.size();i++) ans+=v[i];cout<<ans;
}

WA的原因

赛时没写出来,想到了bfs做法,但总是答案错误,补题也找了好久的错误。发现是我赛时没用vector存每个连通块的最大值,而是又用了一个map来存。这样的话万一多个最大值相同,我的答案就错了。用map的血泪史了……

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/50501.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Elasticsearch概念及ELK安装

1、Elasticsearch是什么 它是elastic技术栈中的一部分。完整的技术栈包括&#xff1a; Elasticsearch&#xff1a;用于数据存储、计算和搜索 Logstash/Beats&#xff1a;用于数据收集 Kibana&#xff1a;用于数据可视化 整套技术栈被称为ELK&#xff0c;经常用来做日志收集…

ansible的role目录结构及用法

目录 目录结构介绍案例 目录结构介绍 可以通可以通过使用 ansible-galaxy 命令再当前目录自动生成 role 的基本目录结构。 myrole为文件名&#xff08;角色名&#xff09; ansible-galaxy init myrole如果没有安装Ansible Galaxy&#xff0c;你可以使用以下命令安装&#xff…

Python 函数的参数形式

Python 函数的参数形式 Python 函数的参数有多种形式&#xff0c;每种形式在不同的场景下使用。我们主要介绍以下几种&#xff1a; 位置参数关键字参数默认参数可变位置参数&#xff08;*args&#xff09;可变关键字参数&#xff08;**kwargs&#xff09; 1. 位置参数 位置…

python题解

宽度与对齐 输出455、-123、987654&#xff0c;宽度为5&#xff0c;分别左对齐和右对齐 格式 输入格式&#xff1a; 无 输出格式&#xff1a; 输出为整型&#xff0c;空格分隔。每个数的输出占一行 样例 1 输入&#xff1a; 无 复制 输出&#xff1a; 455 455 -123 -123 98…

Vue的SSR和预渲染:提升首屏加载速度与SEO效果

引言 在现代Web应用开发中,首屏加载速度和搜索引擎优化(SEO)是衡量应用性能的重要指标。Vue.js 作为流行的前端框架,提供了服务器端渲染(SSR)和预渲染(prerendering)两种技术来提升这些指标。本文将深入探讨如何使用 Vue 的 SSR 和预渲染技术,提供详细的代码示例和最…

FFmpeg源码:av_probe_input_format3函数分析

一、av_probe_input_format3函数的声明 av_probe_input_format3函数声明在FFmpeg源码&#xff08;本文演示用的FFmpeg源码版本为5.0.3&#xff09;的头文件libavformat/avformat.h中&#xff1a; /*** Guess the file format.** param is_opened Whether the file is already…

Go语言的数据结构

数据结构 数组 支持多维数组&#xff0c;属于值类型&#xff0c;支持range遍历 例子&#xff1a;随机生成长度为10整数数组 package main import ("fmt""math/rand" ) // 赋值 随机获取100以内的整数 func RandomArrays() {var array [10]int //声明var…

【MySQL进阶篇】锁:全局锁、表级锁以及行级锁

一、锁的概述 锁是计算机协调多个进程或线程并发访问某一资源的机制。在数据库中除传统的计算资源&#xff08;CPU、RAM、I/O&#xff09;的争用以外&#xff0c;数据也是一种供许多用户共享的资源。如何保证数据并发访问的一致性、有效性是所有数据库必须要解决的一个问题&am…

C语言11 结构体、共用体、枚举和重定义

目录 结构体&#xff08;Struct&#xff09; 定义结构体 声明和初始化结构体变量 访问结构体成员 嵌套结构体 指向结构体的指针 共用体&#xff08;Union&#xff09; 定义共用体 声明和使用共用体 重定义&#xff08;Typedef&#xff09; 定义类型别名 使用类型别…

Person Re-Identification(Re-ID)的分类

行人重识别&#xff08;Person Re-Identification, Re-ID&#xff09;是计算机视觉和深度学习中的一个重要任务&#xff0c;旨在通过图像或视频中的行人外观信息来识别和追踪同一个人在不同摄像头视角下的出现。根据任务的不同&#xff0c;行人重识别可以分为以下几类&#xff…

室内消防逃生通道占用检测AI算法:科技筑防,守护生命通道

随着城市化进程的加快&#xff0c;高层建筑和大型公共场所的数量急剧增加&#xff0c;消防安全问题愈发凸显。其中&#xff0c;室内消防逃生通道的畅通性直接关系到火灾发生时人员的安全疏散。然而&#xff0c;由于各种原因&#xff0c;如杂物堆放、车辆停放等&#xff0c;消防…

nacos 2.3.2 若依使用mysql

1&#xff09;从官网下载 nacos&#xff0c;如果下载慢&#xff0c;关注从本人发布上传下载也可以 2&#xff09;修改配置文件 【config】-【application.properties】 ### Deprecated configuration property, it is recommended to use spring.sql.init.platform replaced.…

SpringBoot实现定时任务-@Scheduled

在Java编程中&#xff0c;Scheduled 注解是 Spring Framework 提供的一个用于定时任务的注解。 Scheduled可以将一个方法配置为定时执行的任务。 以下是一些基本用法&#xff1a; 1.固定速度 fixedRate指两次任务的开始时间间隔。所以存在第二次任务开始时&#xff0c;第一…

LeetCode 2844.生成特殊数字的最少操作(哈希表 + 贪心)

给你一个下标从 0 开始的字符串 num &#xff0c;表示一个非负整数。 在一次操作中&#xff0c;您可以选择 num 的任意一位数字并将其删除。请注意&#xff0c;如果你删除 num 中的所有数字&#xff0c;则 num 变为 0。 返回最少需要多少次操作可以使 num 变成特殊数字。 如…

mysql各个参数调整

innodb_lock_wait_timeout 事务锁释放时间

前端知识--前端访问后端技术Ajax及框架Axios

一、异步数据请求技术----Ajax Ajax是前端访问后端的技术&#xff0c;为异步请求&#xff08;不刷新页面&#xff0c;请求数据&#xff0c;只更新局部数据&#xff09;。 例如&#xff1a;在京东网站中搜索电脑&#xff0c;就会出现一些联想搜索&#xff0c;但此时页面并没有…

【技术支持】canvas转换为图片或PDF保存电脑

注意&#xff1a;有些网站可能由于canvas跨域污染问题&#xff0c;无法使用toBlob&#xff0c;所以无法转换 开发者工具中&#xff0c;选中需要转换的canvas元素&#xff08;使其可以使用$0语法&#xff09; 控制台输入如下代码 $0.toBlob(function (blob) {var link document…

Window下CLion实现本机通过socket通信-C++

1.引言-什么是socket socket即套接字&#xff0c;用于描述地址和端口&#xff0c;是一个通信链的句柄。应用程序通过socket向网络发出请求或者回应。 sockets(套接字)编程有三种&#xff0c;流式套接字&#xff08;SOCK_STREAM&#xff09;&#xff0c;数据报套接字&#xff…

go语言开发Prometheus Exporter(DM数据库)

一、介绍 源码步骤基于dameng_exporter源码讲解&#xff0c;看完本篇文章可以直接进行二次开发。 dameng exporter的开源地址&#xff1a;https://github.com/gy297879328/dameng_exporter&#xff08;可直接对接prometheusgrafana 提供表盘&#xff09; 开发一个exporter 其…

Linux中的三类读写函数

文件IO和标准IO的区别 遵循标准&#xff1a; 文件IO遵循POSIX标准&#xff0c;主要在类UNIX环境下使用。标准IO遵循ANSI标准&#xff0c;具有更好的可移植性&#xff0c;可以在不同的操作系统上重新编译后运行。可移植性&#xff1a; 文件IO的可移植性相对较差&#xff0c;因为…