栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

面试题 04.01:节点间通路

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

面试题 04.01:节点间通路

面试题 04.01:节点间通路
  • 题目
  • 解题
    • 方法一:BFS(迭代)
    • 方法二:DFS(迭代)
    • 方法三:DFS(递归)

题目

题目链接
节点间通路。给定有向图,设计一个算法,找出两个节点之间是否存在一条路径。
示例1:

 输入:n = 3, graph = [[0, 1], [0, 2], [1, 2], [1, 2]], start = 0, target = 2
 输出:true

示例2:

 输入:n = 5, graph = [[0, 1], [0, 2], [0, 4], [0, 4], [0, 1], [1, 3], [1, 4], [1, 3], [2, 3], [3, 4]], start = 0, target = 4
 输出 true

解题 方法一:BFS(迭代)

1.建立邻接表,利用visited数组记录节点是否访问过
2.利用queue进行BFS
3.遍历当前节点的邻接节点,然后返回步骤2,

class Solution {
public:
    bool findWhetherExistsPath(int n, vector>& graph, int start, int target) {
        if(start==target) return true;
        unordered_map> map;
        for(vector& vec:graph){
            map[vec[0]].push_back(vec[1]);
        }
        vector visited(n,false);
        queue queue;
        queue.push(start);
        while(!queue.empty()){
            int cur=queue.front();
            queue.pop();
            visited[cur]=true;
            for(int point:map[cur]){
                if(point==target) return true;
                else if(visited[point]==false) queue.push(point);
            }
        }
        return false;
    }
};
方法二:DFS(迭代)

和广度优先搜索写法上基本无差别,只不过深度优先使用了stack,而广度优先使用了queue。

class Solution {
public:
    bool findWhetherExistsPath(int n, vector>& graph, int start, int target) {
        if(start==target) return true;
        unordered_map> map;
        for(vector& vec:graph){
            map[vec[0]].push_back(vec[1]);
        }
        stack st;
        st.push(start);
        vector visited(n,false);
        while(!st.empty()){
            int cur=st.top();
            st.pop();
            visited[cur]=true;
            for(int point:map[cur]){
                if(point==target) return true;
                else if(visited[point]==false){
                    st.push(point);
                }
            }
        }
        return false;
    }
};
方法三:DFS(递归)

构造邻接表还是一样的。
由于出现一个满足条件的路径就返回,于是dfs的返回值是bool
if(dfs(point,target)) return true; 一旦出现一个true,就递归返回,最终返回结果true;

中止条件:
1.start==end
2.visited[start]==true

class Solution {
private:
    vector visited;
    unordered_map> map;
public:
    bool findWhetherExistsPath(int n, vector>& graph, int start, int target) {
        if(start==target) return true;
        for(vector& vec:graph){
            map[vec[0]].push_back(vec[1]);
        }
        visited=vector(n,false);
        return dfs(start,target);
    }
    bool dfs(int start,int target){
        if(start==target) return true;
        if(visited[start]) return false;
        visited[start]=true;
        for(int point:map[start]){
            if(dfs(point,target)) return true;
        }
        return false;
    }
};
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/644897.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号