day58 第十一章:图论part08

news/2025/2/24 11:30:35

拓扑排序精讲

关键:

先找到入度为0的节点,把这些节点加入队列/结果,然后依次循环再找。

#include <iostream>
#include <vector>
#include <queue>
#include <unordered_map>
using namespace std;
int main() {
    int m, n, s, t;
    cin >> n >> m;
    vector<int> inDegree(n, 0); // 记录每个文件的入度

    unordered_map<int, vector<int>> umap;// 记录文件依赖关系
    vector<int> result; // 记录结果

    while (m--) {
        // s->t,先有s才能有t
        cin >> s >> t;
        inDegree[t]++; // t的入度加一
        umap[s].push_back(t); // 记录s指向哪些文件
    }
    queue<int> que;
    for (int i = 0; i < n; i++) {
        // 入度为0的文件,可以作为开头,先加入队列
        if (inDegree[i] == 0) que.push(i);
        //cout << inDegree[i] << endl;
    }
    // int count = 0;
    while (que.size()) {
        int  cur = que.front(); // 当前选中的文件
        que.pop();
        //count++;
        result.push_back(cur);
        vector<int> files = umap[cur]; //获取该文件指向的文件
        if (files.size()) { // cur有后续文件
            for (int i = 0; i < files.size(); i++) {
                inDegree[files[i]] --; // cur的指向的文件入度-1
                if(inDegree[files[i]] == 0) que.push(files[i]);
            }
        }
    }
    if (result.size() == n) {
        for (int i = 0; i < n - 1; i++) cout << result[i] << " ";
        cout << result[n - 1];
    } else cout << -1 << endl;


}

dijkstra(朴素版)精讲

不能处理负权重,贪心算法,minDist表示距离原点最近的距离。

跟prim一样

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

int main(){
    int n,m,s,e,v;
    cin>>n>>m;
    
    vector<vector<int>> grid(n+1,vector<int>(n+1, INT_MAX));
    for(int i=0;i<m;i++){
        cin>>s>>e>>v;
        grid[s][e]=v;
    }
    
    vector<bool> visited(n+1, false);
    vector<int> minDist(n+1, INT_MAX);
    
    int start = 1;
    minDist[start] = 0;
    for(int i=0;i<n;i++){
        
        int cur = -1;
        int minVal = INT_MAX;
        
        //1.选择未到过的且距离起始点最近车站
        for(int j=1;j<=n;j++){
            if(!visited[j] && minDist[j]<minVal){
                cur = j;
                minVal = minDist[j];
            }
        }
        
        if(cur == -1) {
            break;
        }
        
        //2.到达该车站
        visited[cur] = true;
        
        //3.更新minDist
        for(int j=1;j<=n;j++){
            if(!visited[j] && grid[cur][j]!=INT_MAX && minDist[cur]+grid[cur][j]<minDist[j]){
                minDist[j] = minDist[cur]+grid[cur][j];
            }
        }
        // cout<<"cur="<<cur<<endl;
        // for(int k=1;k<=n;k++){
        //     cout<<minDist[k]<<" ";
        // }
        // cout<<endl;
    }
    
    int count = 0;
    for(int i=1;i<=n;i++){
        if(visited[i]){
            count++;
        }
    }
    
    if(count==n){
        cout<<minDist[n]<<endl;
    }
    else{
        cout<<-1<<endl;
    }
    
    
}


http://www.niftyadmin.cn/n/5864270.html

相关文章

MybatisPlus-注解

TableName设定表名 1. MyBatis-Plus在确定操作的表时&#xff0c;由BaseMapper的泛型决定&#xff0c;即实体类型决 定&#xff0c;且默认操作的表名和实体类型的类名一致 2. 若实体类类型的类名和要操作的表的表名不一致&#xff0c;访问数据库表将会报错 3. 在实体类上添加…

链表和STL —— list 【复习笔记】

1. 链表 1.1 链表的定义和类型 和顺序表一样&#xff0c;链表也是一种线性表&#xff0c;线性表存储结构为链式存储就是链表 链式存储不仅要保存数据元素&#xff0c;还要保存数据元素间的关系&#xff0c;这两个部分信息形成了结点。结点有两个域&#xff1a;数据域&#x…

mysql系列9—mysql的MVCC机制

背景 mysql提供了读未提交、读已提交、可重复读、串行化四种隔离级别&#xff0c;默认的隔离界别为可重复读。其中&#xff0c;不可重复度场景下&#xff0c;每次直接读取最新记录(即使事务未提交)&#xff1b;串行化对于所有的读写都加锁&#xff0c;因此&#xff0c;对二者不…

hive开窗函数边界值ROWS BETWEEN 和 RANGE BETWEEN区别

目录 一、概念 1.rows between ... and ... 2.range between ... and ... 二、语法 1.关键词含义 一、概念 1.rows between ... and ... rows&#xff1a;指以行号来决定frame的范围&#xff0c;是物理意义上的行。 2.range between ... and ... range&#xff1a;指以当…

DeepSeek从入门到精通

1_DeepSeek从入门到精通 (1).pdf官方版下载丨最新版下载丨绿色版下载丨APP下载-123云盘123云盘为您提供1_DeepSeek从入门到精通 (1).pdf最新版正式版官方版绿色版下载,1_DeepSeek从入门到精通 (1).pdf安卓版手机版apk免费下载安装到手机,支持电脑端一键快捷安装https://www.123…

生活教练项目_Trae

XMXALifeCoach - 个人成长辅导网站 网址: https://github.com/zhangxiaomeng1/XMXALifeCoach 项目简介 这是一个基于DeepSeek R1 API开发的个人成长辅导网站。通过与AI进行对话&#xff0c;用户可以获得个性化的建议和指导&#xff0c;帮助个人成长。 技术架构 前端&#xff1a…

使用MyCAT实现分布式MySQL双主架构

Mycat是一个开源的分布式数据库中间件&#xff0c;主要用于提供数据库的分库分表、读写分离、负载均衡等功能。以下是Mycat的几个主要作用&#xff1a; 分库分表&#xff1a;Mycat可以将单个数据库拆分成多个小数据库&#xff0c;并将数据分布在不同的节点上&#xff0c;以提高…

《Mycat核心技术》第17章:实现MySQL的读写分离

作者&#xff1a;冰河 星球&#xff1a;http://m6z.cn/6aeFbs 博客&#xff1a;https://binghe.gitcode.host 文章汇总&#xff1a;https://binghe.gitcode.host/md/all/all.html 星球项目地址&#xff1a;https://binghe.gitcode.host/md/zsxq/introduce.html 沉淀&#xff0c…