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

相关推荐
罗湖老棍子1 天前
【模板】并查集(洛谷P3367)
算法·图论·并查集
wanderist.1 天前
C++输入输出的一些问题
开发语言·c++·图论
Snow_day.2 天前
有关排列排列组合(1)
数据结构·算法·贪心算法·动态规划·图论
初晴や3 天前
【C++】图论:基础理论与实际应用深入解析
c++·算法·图论
闻缺陷则喜何志丹3 天前
【图论 DFS 换根法】3772. 子图的最大得分|2235
c++·算法·深度优先·力扣·图论·换根法
君义_noip5 天前
信息学奥赛一本通 2134:【25CSPS提高组】道路修复 | 洛谷 P14362 [CSP-S 2025] 道路修复
c++·算法·图论·信息学奥赛·csp-s
罗湖老棍子5 天前
信使(msner)(信息学奥赛一本通- P1376)四种做法
算法·图论·dijkstra·spfa·floyd·最短路算法
修炼地5 天前
代码随想录算法训练营第五十三天 | 卡码网97. 小明逛公园(Floyd 算法)、卡码网127. 骑士的攻击(A * 算法)、最短路算法总结、图论总结
c++·算法·图论
罗湖老棍子6 天前
【例4-6】香甜的黄油(信息学奥赛一本通- P1345)
算法·图论·dijkstra·floyd·最短路算法·bellman ford
--JR7 天前
015——图(1.图的相关概念与存储)
数据结构·c++·算法·链表·图论