代码随想录算法训练营第五十七天|图论part7

prim算法精讲

普利姆算法用于求最小生成树

三步:

1.选择离树最近的点

2.该点加入树

3.更新距离表

cpp 复制代码
#include <iostream>
#include <vector>
#include <climits>
using namespace std;


int main(){
    int v,e;
    cin>>v>>e;
    vector<vector<int>>grid(v+1,vector<int>(v+1,10001));
    for(int i=0;i<e;i++){
        int v1,v2,val;
        cin>>v1>>v2>>val;
        grid[v1][v2]=val;
        grid[v2][v1]=val;
    }
    vector<int>minDist(v+1,10001);
    vector<bool>isInTree(v+1,false);
    for(int j=1;j<v;j++){
        //第一步选取距离最小的点
        int min=INT_MAX;   
        int cur;
        for(int i=1;i<=v;i++){    
            if(!isInTree[i]&&minDist[i]<min){
                
                min=minDist[i];
                cur=i;
            }
        }
        //当前节点加入集合
        isInTree[cur]=true;
        //更新当前minDist
        for(int i=1;i<=v;i++){
            if(!isInTree[i]&&grid[cur][i]<minDist[i]){
                minDist[i]=grid[cur][i];
            }
        }
    }
    int ans=0;
    for(int i=2;i<=v;i++){
        ans+=minDist[i];
    }
    cout<<ans;

}

注意!!!vector<vector<int>>grid(v+1,vector<int>(v+1,10001));

这一行很重要

不能初始化为0 这样不存在的边的权值为0 ,应该把不存在的边的权值设为最大值!!!!!!!

kruskal算法精讲

lambda表达式:

一句话:

"一次性、匿名、可调用对象 ",本质上编译器帮你生成一个未命名的函数对象类(closure type)。

"方括号抓变量,圆括号写参数,箭头指返回,花括号干正事。"

capture \] ( parameter_list ) { body } ```cpp #include #include #include using namespace std; int n=10000; struct edge{ int v1,v2,val; edge(int _v1,int _v2,int _val):v1(_v1),v2(_v2),val(_val){} }; vectorfather(n+1,0); void init(){ for(int i=0;i>v>>e; vectoredges; for(int i=0;i>v1>>v2>>val; edges.push_back(edge(v1,v2,val)); } //排序 sort(edges.begin(),edges.end(),[](edge &a,edge &b){ return a.val

相关推荐
qq_4542450319 小时前
GraphFoundation动态更新图
架构·c#·图论
Rhystt20 小时前
代码随想录算法训练营第六十天|多余的边?从基础到进阶!
开发语言·c++·算法·图论
flying_131420 小时前
图神经网络分享系列-HAN(Heterogeneous Graph Attention Network)(二)
深度学习·神经网络·tensorflow·图论·图神经网络·代码实战·han
kronos.荒2 天前
图论之腐烂橘子_BFS(python)
python·图论·bfs
kronos.荒3 天前
图论之岛屿数量(python)
python·图论
cpp_25014 天前
P8395 [CCC 2022 S1] Good Fours and Good Fives
数据结构·c++·算法·动态规划·图论·题解·洛谷
乐观勇敢坚强的老彭4 天前
c++图论
开发语言·c++·图论
不染尘.5 天前
欧拉路径算法
开发语言·数据结构·c++·算法·图论
ab1515176 天前
3.23完成进阶45、84,二刷基础132、129
算法·深度优先·图论
jing-ya6 天前
day 60 图论part11
java·数据结构·算法·图论