小美的修路(最小生成树练习)

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

题目:

样例:

输入
3 4
1 2 3 1
1 2 2 0
1 3 1 0
2 3 3 0
输出
2
1 3

思路:

        由题意,这里建造的城市需要修路,且每个城市之间可以联通,且 是 1 的标记,一定有该方案,0 可自主选择该修路方案,问最少花费修路费用,。

根据题干 ‘每个城市之间可以联通’ 相当于 每个结点都需要遍历一遍,这个修路,就是边权。

这里只是多了一个 标记需要优先选择,根据数据范围,我们还是用 Kruskal 算法即可。

代码详解如下:

#include <iostream>
#include <vector>
#include <queue>
#include <cstring>
#include <algorithm>
#include <unordered_map>
#define endl '\n'
#define YES puts("YES")
#define NO puts("NO")
#define umap unordered_map
#define All(x) x.begin(),x.end()
#pragma GCC optimize(3,"Ofast","inline")
#define IOS std::ios::sync_with_stdio(false),cin.tie(0), cout.tie(0)
using namespace std;
const int N = 2e6 + 10;int n,m;struct Edge
{int a,b,w,p,id;// 定义排序规则,标记 1 的为优先选择方案// 之后排序 最小花费的边权为 优先可选择的方案inline bool operator<(const Edge&t)const{if(p != t.p) return p > t.p;return w < t.w;}
}edge[N];umap<int,int>r;	// 存储集合所对应的连接点// 查找对应的城市 根节点函数
inline int Find(int &x)
{int t = x;while(x != r[x]) x = r[x];r[t] = x;return x;
}vector<int>plan;
inline bool Kruskal()
{// 排序好优先选择的方案sort(edge + 1,edge + m + 1);// 初始化城市点的根节点为自身for(int i = 0;i <= n;++i) r[i] = i;int cnt = 0;	// cnt 用于记录修路的数量// 遍历所有方案for(int i = 1;i <= m;++i){// 获取需要修路的对应两个城市int a = edge[i].a;int b = edge[i].b;// 查找对应两个城市的根节点a = Find(a),b = Find(b);if(edge[i].p || a != b){// 如果这两个城市之间没有连接过// 或者它们是必选方案,那么将它们连接起来r[a] = b;// 累加方案数plan.emplace_back(edge[i].id);++cnt;	// 累加可以修的路数量}}// 如果所修的路无法将所有城市联通,返回 falseif(cnt < n - 1) return false;return true;	// 否则返回 true
}// 打印方案数函数
inline void PrintPlan()
{cout << plan.size() << endl;for(int i : plan){cout << i << ' ';}
}inline void solve()
{// 输入各个信息cin >> n >> m;for(int i = 1;i <= m;++i){int a,b,w,p;cin >> a >> b >> w >> p;// 存储好方案edge[i] = {a,b,w,p,i};}// 开始克鲁斯卡尔算法,判断是否有解,并输出对应答案if(Kruskal()) PrintPlan();else puts("-1");
}int main()
{
//	freopen("a.txt", "r", stdin);IOS;int _t = 1;
//	cin >> _t;while (_t--){solve();}return 0;
}

最后提交:

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

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

相关文章

2023年马丁·加德纳聚会数学魔术分享之《不只是奇偶性的魔术》回顾

早点关注我&#xff0c;精彩不错过&#xff01; 我们的年度之约又来啦&#xff01; 2023马丁聚会盛况 三年疫情的阴霾终于渐渐散去&#xff0c;今天本是有机会线下见一见网友们的一年。本来都收到武元元的通知&#xff0c;在考虑参加一次线下&#xff0c;哪知消息还没焐热就因故…

Ant Design Vue UI框架的基础使用,及通用后台管理模板的小demo【简单】

一、创建 VUE 项目 npm create vuelatest二、安装使用 ant-design-vue 安装脚手架工具 $ npm install -g vue/cli # OR $ yarn global add vue/cli使用组件 # 安装 $ npm i --save ant-design-vue4.x全局完整注册 import { createApp } from vue; import Antd from ant-de…

Python爬虫防止被封的方法:动态代理ip

目录 前言 一、为什么需要使用动态IP代理 1.网站反爬虫机制 2.突破本地IP限制 3.获取更多数据 二、Python爬虫动态IP代理的实现方法 1.使用第三方库 2.使用爬虫框架 三、预防被封的方法 1.代理池管理 2.请求间隔设置 3.使用多个代理 总结 前言 在进行网站爬取时&…

2023年香水行业数据分析:国人用香需求升级,高端香水高速增长

在人口结构变迁的背景下&#xff0c;“Z世代”作为当下我国的消费主力&#xff0c;正在将“悦己”消费推动成为新潮流。具备经济基础的“Z世代”倡导“高颜值”、“个性化”、“精致主义”&#xff0c;这和香水、香氛为代表的“嗅觉经济”的特性充分契合&#xff0c;因此&#…

jenkins如何安装?

docker pull jenkins/jenkins:lts-centos7-jdk8 2.docker-compose.yml version: 3 services:jenkins:image: jenkins/jenkins:lts-centos7-jdk8container_name: my-jenkinsports:- "8080:8080" # 映射 Jenkins Web 界面端口volumes:- jenkins_home:/var/jenkins_h…

53. 寻宝(第七期模拟笔试)(最小生成树练习)

本题链接&#xff1a;卡码网KamaCoder 题目&#xff1a; 样例&#xff1a; 输入 7 11 1 2 1 1 3 1 1 5 2 2 6 1 2 4 2 2 3 2 3 4 1 4 5 1 5 6 2 5 7 1 6 7 1 输出 6 思路&#xff1a; 由题意&#xff0c;这里是需要遍历完全部的顶点&#xff0c;求遍历完全部点的花费最短距离…

轻量级仿 Spring Boot=嵌入式 Tomcat+Spring MVC

啥&#xff1f;Spring Boot 不用&#xff1f;——对。就只是使用 Spring MVC Embedded Tomcat&#xff0c;而不用 Boot。为啥&#xff1f;——因为 Boot 太重了&#xff1a;&#xff09; 那是反智吗&#xff1f;Spring Boot 好好的就只是因为太重就不用&#xff1f;——稍安勿…

电脑技巧:Win10飞行模式相关知识介绍

目录 一、飞行模式简介 二、如何开关Windows 10中的飞行模式 方法一&#xff1a;使用硬件开关 方法二&#xff1a;使用Windows 10操作中心 方法三&#xff1a;使用Windows 10设置 三、飞行模式开关被卡住、变灰或不工作时怎么办 什么是 Windows 10 飞行模式? 用户如何打…

07.K8S高可用集群节点规划

K8S高可用集群节点规划 1、部署拓扑图 2、master节点数(物理机数) 总数最少存活失败容忍说明110单个主节点时使用220不推荐321推荐431不推荐532推荐642不推荐743可以考虑&#xff0c;但会导致确定集群成员和仲裁的开销加大853不推荐954可以考虑&#xff0c;但会导致确定集群成…

大模型在数据分析场景下的能力评测

“你们能对接国产大模型吗&#xff1f;” “开源的 LLaMA 能用吗&#xff0c;中文支持怎么样&#xff1f;” “私有化部署和在线服务哪个更合适&#xff1f;” 自 7 月 14 日发布 AI 数智助理 Kyligence Copilot 后&#xff0c;我们收到了很多类似上面的咨询&#xff0c;尤其…

C# | Chaikin算法 —— 计算折线对应的平滑曲线坐标点

Chaikin算法——计算折线对应的平滑曲线坐标点 本文将介绍一种计算折线对应的平滑曲线坐标点的算法。该算法使用Chaikin曲线平滑处理的方法&#xff0c;通过控制张力因子和迭代次数来调整曲线的平滑程度和精度。通过对原始点集合进行切割和插值操作&#xff0c;得到平滑的曲线坐…

淘宝API接口获取商品信息,订单管理,库存管理,数据分析

在淘宝开放平台中&#xff0c;每个API接口都有相应的文档说明和授权机制&#xff0c;以确保数据的安全性和可靠性。开发者可以根据自己的需求选择相应的API接口&#xff0c;并根据文档说明进行调用和使用。 淘宝开放平台API接口是一套REST方式的开放应用程序编程接口&…