代码随想录算法训练营第五十七天|图论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

相关推荐
菜鸟555552 小时前
图论:SPFA算法
算法·图论
皮蛋瘦肉粥_12114 小时前
代码随想录day51图论2
图论
limitless_peter16 小时前
图论(BFS)构造邻接表(运用队列实现搜索)
算法·图论
小指纹18 小时前
图论-最短路 Bellman-Ford算法
c++·算法·objective-c·图论
Ahu_iii19 小时前
【图论基础】理解图的“闭环”:Tarjan 强连通分量算法全解析
算法·图论
小蛋编程3 天前
【算法-图论】图的存储
c++·算法·图论
今天你睡了嘛3 天前
数据结构——图(二、图的存储和基本操作)
数据结构·算法·图论
KyollBM3 天前
【CF】Day114——杂题 (贪心 + 图论 | LCM + 贪心 | 最大最小子序列 + 图论)
算法·图论
YouQian7724 天前
绳子切割 图论
图论