当前位置: 首页 > news >正文

day58 第十一章:图论part08

拓扑排序精讲

关键:

先找到入度为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;
    }
    
    
}

相关文章:

  • 基于SpringBoot的线上景区订票系统的设计与实现(源码+SQL脚本+LW+部署讲解等)
  • c语言 枚举用法技巧
  • Linux搭建Nginx直播流媒体服务RTMP/RTSP转Http-flv视频浏览器在线播放/Vue/Java/ffmpeg
  • 设计模式-组合模式、模板模式
  • 【Python + STM32 实现外设控制的从0-1实例教程-适合新手】
  • 数据结构与算法再探(七)查找-排序
  • DeepSeek-R1本地部署保姆级教程
  • C++核心指导原则: 枚举
  • 图像处理篇---图像处理中常见参数
  • DataX 抽取 MySQL 数据教程
  • 网络运维学习笔记 021 HCIA-Datacom新增知识点02 SDN与NFV概述
  • Pytorch深度学习教程_5_编写第一个神经网络
  • AWQ和GPTQ量化的区别
  • Linux基本操作
  • Linux 命令大全完整版(11)
  • 用JAVA实现人工智能:采用框架Spring AI Java
  • 前端实现socket 中断重连
  • Deepin(Linux)设置开机自动启动 MySQL
  • 智能测试执行 利用算法 利用图像识别、自然语言处理等技术实现自动化测试执行
  • C#上位机--跳转语句
  • 新买的服务器怎么做网站/seo基础培训机构
  • 2017网站建设价目表/个人在线做网站免费
  • 营销型网站(易网拓)/日本粉色iphone
  • 设计室内效果图设计/微博关键词排名优化
  • 河南省汝州市建设网站/百度数据研究中心官网
  • 佛山龙江做网站的/怎么写软文推广