深度優先搜尋
習題預習
User ask:
給我5題Depth-First Search的中文問題
ChatGPT answer:如何使用深度優先搜索算法(DFS)在無向圖中尋找所有連通份量?
使用DFS尋找無向圖中的最長路徑是如何實現的?
如何使用DFS在有向無環圖中查找最長路徑?
如果我想要使用DFS在迷宮中找到出口,應該如何實現?
如何使用DFS找到一張圖中所有的割點(關鍵節點)?
說明知識
User ask:
以中文說明Depth-First Search並舉例
ChatGPT answer:Depth-First Search(DFS)是一種遍歷圖(Graph)或樹(Tree)的演算法,以從起點(Start)開始,往下搜索並幾乎盡可能地走到底部,然後返回搜索路徑,直到發現無法再繼續為止。
DFS遍歷圖的步驟如下:
- 選擇一個未被訪問過的節點當作起點。
- 訪問該節點,將其標記為已訪問。
- 對該節點的相鄰節點進行遍歷,如果相鄰節點未訪問過,就按照相同的方式進行訪問,如果已經訪問過,則返回上一個節點繼續遍歷。
- 重複步驟3,直到所有節點都被訪問過。
以下是一個DFS的示例,設有一個圖如下所示:
A —— B —— C
| |
D —— E
從節點A開始,先把它標記為已訪問,然後從它的相鄰節點中選擇B進行訪問。對節點B進行訪問,在其相鄰節點中選擇C進行訪問,當C訪問完畢,返回B,然後選擇E進行訪問,接下來訪問D,再返回A,最後訪問完畢。
在此遍歷過程中,每個節點只被訪問一次,所以時間複雜度為O(V+E),其中V是節點數,E是邊數。
條列重點
User ask:
以中文條列Depth-First Search的重點
ChatGPT answer:- DFS 是一種搜索算法,它是以深度為優先考慮,在搜索過程中盡可能深入地訪問每個可訪問節點。
- DFS 是一種遞歸算法,使用棧(stack)或者遞歸來實現。
- DFS 可以用於求解圖或樹的遍歷、連通性、最短路徑等問題。
- DFS 算法的時間複雜度為 O(V+E),其中 V 表示節點數,E 表示邊數。
- 在 DFS 中,可以通過標記已訪問節點或使用 visited 數組來避免無限遞歸的問題。
- DFS 算法分為前序遍歷、中序遍歷和後序遍歷三種方式。
- DFS 可以應用到許多問題中,例如迷宮求解、拓撲排序、詞法分析、圖像處理等。
知識測驗
User ask:
以中文給我5題Depth-First Search的中等難度問題,並在後面列出答案
ChatGPT answer:- 岛屿数量:给定一个由‘0’和‘1’组成的二维网格地图,其中‘1’表示陆地,‘0’表示海水。计算这个地图上岛屿的数量。(LeetCode 200)
答案:https://leetcode.com/problems/number-of-islands/solution/
- 从键盘输入一个有向图的邻接矩阵,输出其深度优先遍历序列。
答案:https://www.geeksforgeeks.org/depth-first-search-or-dfs-for-a-graph/
- 朋友圈的数量:在一个社交圈子里,有 N 个人。每个人都有若干个朋友,这些关系用一个二维矩阵表示,矩阵中的 1 表示两个人互为朋友,0 表示不是。判断这个圈子里有多少个朋友圈。 (LeetCode 547)
答案:https://leetcode.com/problems/friend-circles/solution/
- 课程安排:将课程表表示成一个名为prerequisites的二维数组,其中 prerequisites[i] = [ai, bi] 表示要想学习课程 i,在修完课程 ai 后必须先修完课程 bi。如果一条直接的修课路线可以完成所有课程程度,则返回 true;否则,返回 false 。(LeetCode 207)
答案:https://leetcode.com/problems/course-schedule/solution/
- 机器人运动范围:地上有一个 m 行和 n 列的方格,机器人从坐标 (0, 0) 的格子开始移动,每次可以向上、下、左、右四个方向移动一格,但不能进入坐标数位之和大于 k 的格子,求机器人能到达多少个格子。(剑指Offer 13)
答案:https://leetcode.com/problems/ji-qi-ren-de-yun-dong-fan-wei-lcof/solution/