首页 > 编程语言 >代码随想录算法训练营 | 所有可达路径

代码随想录算法训练营 | 所有可达路径

时间:2024-11-13 16:20:31浏览次数:1  
标签:paths int graph 训练营 随想录 算法 vector path visited

所有可达路径

文章链接:https://programmercarl.com/kamacoder/0098.所有可达路径.html#本题代码
题目链接:https://kamacoder.com/problempage.php?pid=1170

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

//全局路径
vector<vector<int>> paths;
vector<int> path;

void dfs(vector<vector<int>> graph,vector<bool> &visited,int x,int n){
    //递归结束条件
    if(x==n){
        paths.push_back(path);
        return;
    }
    for(int i=1;i<=n;i++){
        if(graph[x][i]==1&&visited[i]==false){
            path.push_back(i);
            visited[i]=true;
            dfs(graph,visited,i,n);
            visited[i]=false;//回溯
            path.pop_back();//回溯
        }
    }
}

int main(){
    int n,m;
    cin>>n>>m;
    //创建n*n的邻接矩阵
    vector<vector<int>> graph(n+1,vector<int>(n+1,0));
    vector<bool> visited(n+1,false);
    while(m--){
        int s,t;
        cin>>s>>t;
        graph[s][t]=1;
    }
    //一开始就已经从节点1开始了,故这里初始化path,和visited[1]
    path.push_back(1);
    visited[1]=true;
    dfs(graph,visited,1,n);
    
    // 输出结果
    if (paths.size() == 0) cout << -1 << endl;
    for (const vector<int> &pa : paths) {
        for (int i = 0; i < pa.size() - 1; i++) {
            cout << pa[i] << " ";
        }
        cout << pa[pa.size() - 1]  << endl;
    }
    
}

总结:这里在随想录中没有将会形成环的路径排除,所以我加了一个visited数组,用来记录已经访问过的节点。

标签:paths,int,graph,训练营,随想录,算法,vector,path,visited
From: https://www.cnblogs.com/VickyWu/p/18544236

相关文章

  • c语言第九课,各种算法
    选择排序选择排序(从未排序列找到最值,放到排序序列的起始位置)#include<stdio.h>voidselect_sort(inta[],intn)//定义选择排序函数{  for(inti=0;i<n-1;i++)//遍历数组找到最小的元素索引,n-1是因为最后一次可以排序两个  {    intmin=i;//假......
  • 洛谷题单 算法2-2 常见优化技巧
    洛谷题单算法2-2常见优化技巧单调栈单调栈最经典的应用,就是在一个数列里寻找距离元素最近的比其大/小的元素位置。模板题,寻找每个元素右边第一个比它大的元素下标。stack<int>s;for(inti=n;i>=1;i--){while(s.size()&&a[s.top()]<=a[i])s.pop();f[i]=s.......
  • 非煤矿山算法智慧矿山一体机提升机危险区域违规闯入识别边坡监测预警系统详述
    在矿山行业中,安全始终是最为关键的议题。随着智能化技术的发展,智慧矿山一体机应运而生,它专为矿山安全监控和管理设计,集成了多种智能化功能,以提升矿山的安全监管能力和生产效率。这款设备不仅能够满足矿山场景下的视频智能化建设需求,还能够通过边缘计算技术实现对矿山安全风险的实......
  • 【算法学习】单调队列优化dp
    前言这已经是很基础很模板化的优化了,我们可以理解为用贪心的思路去掉了永远不可能用到的状态,通常用于长度固定是个区间、最大值且满足单调性的题目。如果一个选手比你小,还比你强,你就永远也打不过他了。这很残酷但这也是单调队列的思想,虽然现实情况比较多变。P3572[POI2014]PT......
  • 街面环卫算法视频分析服务器沿街晾晒智慧城管算法详解
    在城市精细化管理的背景下,智慧城管和街面秩序维护的需求日益增长。为了提高城市管理效率,确保城市秩序和市容市貌,一款集高清视频监控、智能分析与告警、数据资源共享服务于一体的智能化一体机设备应运而生。本文将详细介绍街面环卫算法视频分析服务器的功能特点以及其在智慧城管和......
  • 视频智能分析网关视频分析网关工服检测算法:提升安全监管效率的关键技术
    随着AI技术的持续发展,智能视频分析网关已经成为多个行业安全监控的关键设备。在这些网关中,工服检测算法作为一项关键技术,利用深度学习和计算机视觉技术,能够实时监控并分析监控视频中工作人员的工服穿着情况。本文将详细分析视频智能分析网关视频分析网关的工服检测算法,并探讨其在......
  • 烟火检测视频分析网关算法网关智慧工厂安全生产视频监管方案
    在数字化时代,企业转型升级已成为实现可持续发展的必由之路。特别是在工业领域,工厂的智能化转型不仅能够提高生产效率,还能加强安全管理,确保员工的健康与安全。TSINGSEE青犀AI智能分析网关V4与安防监控视频管理系统EasyCVR视频融合平台的结合,为工厂提供了一个实现智能化转型、构建智......
  • 百万数据做支撑,智能算法赋能标准查重工作全面升级
    标准查重—快速检查标准重复度—在标准编制过程中,查重工作是确保标准质量、维护其科学性与原创性的重要环节。例如,在编制某一特定行业的产品质量标准时,需要与该行业已有的国家、行业、地方标准进行全面比对,查看是否存在重复条款、相似表述等情况。尤其是在全球化背景下,很多......
  • 代码随想录算法训练营第二十四天| leetcode93.复原IP地址、 leetcode78.子集、leetcod
    1leetcode93.复原IP地址题目链接:93.复原IP地址-力扣(LeetCode)文章链接:代码随想录视频链接:回溯算法如何分割字符串并判断是合法IP?|LeetCode:93.复原IP地址_哔哩哔哩_bilibili思路:就是将这个字符串符合要求的进行一个收集,然后使用列表存储,最后使用join函数将这个列表进行连......
  • 代码随想录——二叉树17-路径总和
    这两道题目对于递归函数的返回值是不同的,这里进行总结,二叉树遍历中递归函数返回值何时有何时没有。这里总结如下三点:如果需要搜索整棵二叉树且不用处理递归返回值,递归函数就不要返回值。(这种情况就是路径总和ii)如果需要搜索整棵二叉树且需要处理递归返回值,递归函数就需......