程序员面试金典 - 面试题 04.01. 节点间通路(图的遍历)

1. 题目

节点间通路。给定有向图,设计一个算法,找出两个节点之间是否存在一条路径。

示例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提示:
节点数量n在[0, 1e5]范围内。
节点编号大于等于 0 小于 n。
图中可能存在自环和平行边。

2. 解题

  • 邻接矩阵 内存超限
class Solution {
public:bool findWhetherExistsPath(int n, vector<vector<int>>& graph, int start, int target) {bool visited[n] = {false};visited[start] = true;queue<int> q;int tp, i;q.push(start);vector<vector<int>> map(n,vector<int>(n,0));for(i = 0; i < graph.size(); ++i)map[graph[i][0]][graph[i][1]] = 1;while(!q.empty()){tp = q.front();q.pop();if(tp == target)return true;for(i = 0; i < n; ++i){if(!visited[i] && map[tp][i]==1){visited[i] = true;q.push(i);}}}return false;}
};
  • 邻接表 BFS
class Solution {
public:bool findWhetherExistsPath(int n, vector<vector<int>>& graph, int start, int target) {bool visited[n] = {false};visited[start] = true;vector<vector<int>> map(n);int i, tp;for(i = 0; i < graph.size(); ++i){map[graph[i][0]].push_back(graph[i][1]);}queue<int> q;q.push(start);while(!q.empty()){tp = q.front();if(tp == target)return true;q.pop();for(i = 0; i < map[tp].size(); ++i){if(!visited[map[tp][i]]){q.push(map[tp][i]);visited[map[tp][i]] = true;}}}return false;}
};

在这里插入图片描述

  • 邻接表 DFS
class Solution {
public:bool findWhetherExistsPath(int n, vector<vector<int>>& graph, int start, int target) {bool visited[n] = {false};visited[start] = true;vector<vector<int>> map(n);for(int i = 0; i < graph.size(); ++i){map[graph[i][0]].push_back(graph[i][1]);}bool found = false;dfs(map,start,target,found,visited);return found;}void dfs(vector<vector<int>>& map , int start, int& target, bool& found, bool* visited){if(start == target)found = true;if(found)return;for(int i = 0; i < map[start].size(); ++i){if(!visited[map[start][i]]){visited[map[start][i]] = true;dfs(map,map[start][i],target,found,visited);visited[map[start][i]] = false;}}}
};

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/476977.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

签名程序集密钥文件路径

在AssemblyInfo.cs 文件中 [assembly: AssemblyKeyFileAttribute("文件名")] 文件名是以解决方案.sln文件的路径为准的相对路径转载于:https://www.cnblogs.com/hjf1223/archive/2005/09/14/236590.html

华为天才少年谢凌曦:关于视觉识别领域发展的个人观点

文 | 谢凌曦知乎最近&#xff0c;我参加了几个高强度的学术活动&#xff0c;包括CCF计算机视觉专委会的闭门研讨会和VALSE线下大会。经过与其他学者的交流&#xff0c;我产生了许多想法&#xff0c;千头万绪&#xff0c;便希望把它们整理下来&#xff0c;供自己和同行们参考。当…

程序员面试金典 - 面试题 04.03. 特定深度节点链表(BFS)

1. 题目 给定一棵二叉树&#xff0c;设计一个算法&#xff0c;创建含有某一深度上所有节点的链表&#xff08;比如&#xff0c;若一棵树的深度为 D&#xff0c;则会创建出 D 个链表&#xff09;。返回一个包含所有深度的链表的数组。 例&#xff1a; 输入&#xff1a;[1,2,3,…

microsoft WINDOWS 系统错误代码 [收藏]

MS Windows Error Messages Code Error Message 0 操作成功完成。 1 功能错误。 2 系统找不到指定的文件。 3 系统找不到指定的路径。 4 系统无法打开文件。 5 拒绝访问。 6 句柄无效。 7 存储控制块被损坏。 8 存储空间不足&#xff0c;无法处理此命…

月薪3w算法工程师日均7行代码被开除 / AI歌手入学上海音乐学院 / 天文照片被植入恶意代码...

文 | 日报君 发自 凹非寺源 | 量子位又到周四&#xff0c;不少人心中的「小周末」&#xff01;你有没考虑下班后放松放松&#xff1f;劳逸结合&#xff0c;别忘关注这些「科技圈都在看」的新鲜事&#xff01;今日大新闻月薪3.6万算法工程师&#xff0c;日均写7行代码被开除&…

程序员面试金典 - 面试题 04.04. 检查平衡性(二叉树高度)

1. 题目 实现一个函数&#xff0c;检查二叉树是否平衡。在这个问题中&#xff0c;平衡树的定义如下&#xff1a;任意一个节点&#xff0c;其两棵子树的高度差不超过 1。 示例 1: 给定二叉树 [3,9,20,null,null,15,7]3/ \9 20/ \15 7 返回 true 。示例 2: 给定二叉树 [1,2…

火树银花的夜晚

好些年前就想看国际音乐烟花节&#xff0c;但不是有事就是错过了买票的时间&#xff0c;这次很早就订好了票子一定要去凑个热闹~&#xff01;特定定了6号希腊专场&#xff0c;结果看来很明智&#xff0c;3号那天这么大的雨&#xff0c;哈哈&#xff01;上午去看了《神话》&…

扩散模型背后的数学太难,谷歌发论文带路

源 | 机器之心扩散模型背后的数学可是难倒了一批人。最近一段时间&#xff0c;AI 作画可谓是火的一塌糊涂。在你惊叹 AI 绘画能力的同时&#xff0c;可能还不知道的是&#xff0c;扩散模型在其中起了大作用。就拿热门模型 OpenAI 的 DALLE 2 来说&#xff0c;只需输入简单的文本…

程序员面试金典 - 面试题 04.05. 合法二叉搜索树(中序遍历)

1. 题目 实现一个函数&#xff0c;检查一棵二叉树是否为二叉搜索树。 示例 1: 输入:2/ \1 3 输出: true示例 2: 输入:5/ \1 4/ \3 6 输出: false 解释: 输入为: [5,1,4,null,null,3,6]。根节点的值为 5 &#xff0c;但是其右子节点值为 4 。2. 解题 该题要求严格&…

2 MyWarCraftStudio v0.6版

MyWarCraftStudio v0.6版,可以查看Wow的BLP2、M2、WMO、WDL、ADT、DBC格式的文件 如题。平民程序2005.03.11放出。大家可去平民程序下载&#xff1a;http://blog.gameres.com/show.asp?BlogID144&column0// --- 这个Blog作者不再更新了&#xff0c;如果下载不了&#xff0…

我是如何从头开始写一篇顶级论文的

文 | 重剑无锋知乎源 | 极市平台关于一篇顶会论文是如何产生的这件事—且看作者为你娓娓道来&#xff0c;如何从一形成routine的日常科研生活中挖掘到巧妙的产出。最近完成了一篇很满意的论文&#xff0c;不仅整个过程愉快&#xff0c;回味无穷&#xff0c;而且真正做到了“学术…

程序员面试金典 - 面试题 05.06. 整数转换(位运算)

1. 题目 整数转换。编写一个函数&#xff0c;确定需要改变几个位才能将整数A转成整数B。 示例1:输入&#xff1a;A 29 &#xff08;或者0b11101&#xff09;, B 15&#xff08;或者0b01111&#xff09;输出&#xff1a;2示例2:输入&#xff1a;A 1&#xff0c;B 2输出&am…

论文模型构建的步骤_【论文分享】AiR:具有推理能力的注意力模型框架

大家好&#xff0c;今天我们分享一篇来自于ECCV 2020的论文《AiR: Attention with Reasoning Capability》。这篇论文主要研究的是在视觉推理过程中&#xff0c;人和机器的注意力在时域上的渐进变化。论文代码​github.com一. 论文的动机现有的工作在视觉任务中&#xff0c;例如…

第一次Blog

没有经验请多关照转载于:https://www.cnblogs.com/oiramario/archive/2005/10/18/257414.html

这可能是中国最穷的211大学!连研究生奖学金都发不起了....

源 | 募格学术万万没想到曾经因为“穷”而登上了微博热搜榜的西北大学。最近又因为“没钱”惹的祸而闯上了风口浪尖....近日&#xff0c;西北大学因研究生奖学金发放问题引发关注。起因是临近开学&#xff0c;西北大学通知调整奖学金发放政策&#xff0c;不仅取消了考研新生的奖…

LintCode 1862. 给树浇水的时间(图的遍历)

1. 题目 有一棵n个节点的树&#xff0c;节点编号是0至 n−1&#xff0c;其中 0号节点是根节点&#xff0c;i号节点的父亲节点是father[i] 。 现在要对树浇水&#xff0c;把水撒到根节点上&#xff0c;水会顺着每一条边流下去&#xff0c;从 i 号节点的父亲流到 i 号节点需要 …

potainer 日志_日志系统落地:制定日志规范

我们的系统&#xff0c;已经接入阿里云的日志服务很长一段时间了&#xff0c;存了数以TB级别的日志&#xff0c;突然有一天&#xff0c;领导说&#xff0c;我们需要所有订单的ip信息用于审计订单的真实性&#xff0c;突然发现日志系统无法一次性查找到我所有需要的信息&#xf…

软件项目管理的质量保证

软件工程项目管理是一个系统工程&#xff0c;软件工程项目管理的主要目标是保证项目在规定时间内高质量地完成。项目管理包括了项目组开发各阶段的人员结构的配置&#xff0c;质量控制的实施方略&#xff0c;内部文档和产品文档的组织编写等多项工作&#xff0c;其中质量控制方…

8 月份 Github 上最火的10篇 AI 论文!

文 | 天于刀刀不晓得各位同学在看论文的时候最关注的是什么&#xff1f;也许是论文的创新点&#xff0c;或是被引用的数量&#xff0c;还是...是不是自带代码&#xff01;重要的事说三遍&#xff01;复现&#xff0c;复现&#xff0c;还是复现&#xff01;(ーー゛)为了方便各位…

LintCode 1859. 最小振幅(排序)

1. 题目 给定一个由 N 个整数组成的数组 A&#xff0c;一次移动&#xff0c;我们可以选择此数组中的任何元素并将其替换为任何值。 数组的振幅是数组A中的最大值和最小值之间的差。 返回通过执行最多三次替换之后数组A的最小振幅 示例 1 输入: A [-9, 8, -1] 输出: 0 解释&a…