首页 > 编程语言 >图论day61:最小生成树|最小生成树理论基础:prim算法、kruskal算法(思维导图版)、53.寻宝(卡码网 第七期模拟笔试)

图论day61:最小生成树|最小生成树理论基础:prim算法、kruskal算法(思维导图版)、53.寻宝(卡码网 第七期模拟笔试)

时间:2024-10-16 12:22:25浏览次数:3  
标签:vector val int 第七期 最小 算法 edges include find

图论day61:最小生成树|最小生成树理论基础:prim算法、kruskal算法(思维导图版)、53.寻宝(卡码网 第七期模拟笔试)

最小生成树理论基础(思维导图版)

在这里插入图片描述

53.寻宝(卡码网 第七期模拟笔试)

题目描述

在世界的某个区域,有一些分散的神秘岛屿,每个岛屿上都有一种珍稀的资源或者宝藏。国王打算在这些岛屿上建公路,方便运输。

不同岛屿之间,路途距离不同,国王希望你可以规划建公路的方案,如何可以以最短的总公路距离将 所有岛屿联通起来(注意:这是一个无向图)。

给定一张地图,其中包括了所有的岛屿,以及它们之间的距离。以最小化公路建设长度,确保可以链接到所有岛屿。

输入描述

第一行包含两个整数V 和 E,V代表顶点数,E代表边数 。顶点编号是从1到V。例如:V=2,一个有两个顶点,分别是1和2。

接下来共有 E 行,每行三个整数 v1,v2 和 val,v1 和 v2 为边的起点和终点,val代表边的权值。

输出描述

输出联通所有岛屿的最小路径总距离

输入示例

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

提示信息

数据范围:
2 <= V <= 10000;
1 <= E <= 100000;
0 <= val <= 10000;

如下图,可见将所有的顶点都访问一遍,总距离最低是6.

1.prim法

#include <iostream>
#include <vector>
#include <climits>
using namespace std;

int main()
{
    int v,e,x,y,k;
    cin>>v>>e;
    vector<vector<int>> grid(v+1,vector<int>(v+1,10001));
    for(int i=0;i<e;i++)
    {
        cin>>x>>y>>k;
        grid[x][y]=k;
        grid[y][x]=k;
    }

vector<int> minDist(v+1,10001);

vector<bool> isInTree(v+1,false);

for(int i=1;i<=v;i++)
{
    int cur=-1;
    int minVal=INT_MAX;
    for(int j=1;j<=v;j++)
        if(!isInTree[j]&&minDist[j]<minVal)
        {
            minVal=minDist[j];
            cur=j;
        }

    isInTree[cur]=true;

    for(int j=1;j<=v;j++)
        if(!isInTree[j]&&grid[cur][j]<minDist[j])
            minDist[j]=grid[cur][j];
}

int result=0;
for(int i=2;i<=v;i++)
    result+=minDist[i];
cout<<result<<endl;
}

2.kruskal法

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

struct Edge
{
    int l,r,val;
};

int n;
vector<int> father(10001,0);

void init()
{
    for(int i=1;i<=n;i++)
        father[i]=i;
}

int find(int u)
{
    return u==father[u]?u:father[u]=find(father[u]);
}

void join(int u,int v)
{
    u=find(u);
    v=find(v);
    if(u==v)
        return;
    else
        father[v]=u;
}

bool cmp(Edge& edge1,Edge& edge2)
{
    return edge1.val<edge2.val;
}

int main()
{
    int e,v1,v2,val;
    cin>>n>>e;
    vector<Edge> edges;
    for(int i=1;i<=e;i++)
    {
        cin>>v1>>v2>>val;
        edges.push_back({v1,v2,val});
    }

    sort(edges.begin(),edges.end(),cmp);

    init();

    int result=0;
    for(int i=0;i<e;i++)
    {
        int x=find(edges[i].l);
        int y=find(edges[i].r);
        if(x!=y)
        {
            result+=edges[i].val;
            join(x,y);
        }
    }
    cout<<result<<endl;
}

分析思路:

在这里插入图片描述

标签:vector,val,int,第七期,最小,算法,edges,include,find
From: https://blog.csdn.net/2402_84438596/article/details/142978371

相关文章

  • 【优选算法】(第四十三篇)
    目录为⾼尔夫⽐赛砍树(hard)题目解析讲解算法原理编写代码01矩阵(medium)题目解析讲解算法原理编写代码为⾼尔夫⽐赛砍树(hard)题目解析1.题目链接:.-力扣(LeetCode)2.题目描述你被请来给⼀个要举办⾼尔夫⽐赛的树林砍树。树林由⼀个mxn的矩阵表⽰,在这个矩阵中:......
  • 【优选算法】(第四十四篇)
    目录⻜地的数量(medium)题目解析讲解算法原理编写代码地图中的最⾼点(medium)题目解析讲解算法原理编写代码⻜地的数量(medium)题目解析1.题目链接:.-力扣(LeetCode)2.题目描述给你⼀个⼤⼩为mxn的⼆进制矩阵grid,其中0表⽰⼀个海洋单元格、1表⽰⼀个陆地单......
  • 3194. 最小元素和最大元素的最小平均值
    你有一个初始为空的浮点数数组averages。另给你一个包含n个整数的数组nums,其中n为偶数。你需要重复以下步骤n/2次:从nums中移除最小的元素minElement和最大的元素maxElement。将(minElement+maxElement)/2加入到averages中。返回averages中的最......
  • R语言使用caret包构建神经网络模型(Neural Network )构建回归模型实战、通过method参数
    R语言使用caret包构建神经网络模型(NeuralNetwork )构建回归模型实战、通过method参数指定算法名称目录R语言使用caret包构建神经网络模型(NeuralNetwork )构建回归模型、通过method参数指定算法名称 #导入包和库#仿真数据#R语言使用caret包构建随机森林模型(randomfore......
  • 常用加解密算法详解与应用指南
    1.引言加解密算法是保证数据安全的基础技术,无论是在数据传输、存储,还是用户身份验证中,都起着至关重要的作用。随着互联网的发展和信息安全威胁的增加,了解并掌握常用的加解密算法已经成为开发者和安全从业者的必修课。本文将详细介绍几种常见的加解密算法,包括对称加密、非......
  • python 实现旋转图片算法
    旋转图片算法介绍旋转图片算法是图像处理中常用的一种技术,它可以将图像中的对象旋转到特定的角度。这种算法在图像处理、计算机视觉、人工智能等领域都有广泛的应用,例如自动驾驶、医学影像、安防监控等场景。以下是旋转图片算法的基本步骤:确定旋转中心点:旋转操作通常围绕......
  • 阿里 C++面试,算法题没做出来,,,
    我本人是非科班学C++ 后端和嵌入式的。在我面试的过程中,竟然得到了阿里​C++研发工程师的面试机会。因为,阿里主要是用Java比较多,C++的岗位比较少​,所以感觉这个机会还是挺难得的。阿里C++研发工程师面试考了我一道类似于快速排序算法的算法题,虽然我算法题又一次没做......
  • 基于常青藤算法优化深度混合核极限学习机(IVY-DHKELM)的数据多变量回归预测 Matlab (
    [原创]基于常青藤算法优化深度混合核极限学习机(IVY-DHKELM)的数据多变量回归预测Matlab(多输入单输出)程序已经调试好,无需更改代码替换数据集即可运行!!!数据格式为excel!①将多项式核函数与高斯核函数加权结合,构造出新的混合核函数,并引入自动编码器对极限学习机进行改进,建......
  • 基于网格搜索优化最小二乘向量机(GS-LSSVM)的数据多变量回归预测 Matlab代码(多输入单
    基于网格搜索优化最小二乘向量机(GS-LSSVM)的数据多变量回归预测Matlab代码(多输入单输出)程序已经调试好,无需更改代码替换数据集即可运行!!!数据格式为excel!网格搜索GS优化参数为:sigma、gamma1.购买前GS可以更换为其他的优化算法!需要其他算法的都可以定制!注:1️⃣、运行环境要......
  • 【优选算法篇】双指针的华丽探戈:深入C++算法殿堂的优雅追寻
    文章目录C++双指针详解:进阶题解与思维分析前言第一章:有效三角形的个数1.1有效三角形的个数示例1:示例2:解法一(暴力求解)解法二(排序+双指针)易错点提示代码解读第二章:和为s的两个数字2.1和为s的两个数字示例1:解法一(暴力解法)解法二(双指针-对撞指针)第三章:三......