圖論回溯

圖論

200.島嶼數量DFS

給你一個由 ‘1’(陸地)和 ‘0’(水)組成的的二維網格,請你計算網格中島嶼的數量。島嶼總是被水包圍,并且每座島嶼只能由水平方向和/或豎直方向上相鄰的陸地連接形成。此外,你可以假設該網格的四條邊均被水包圍。

深度優先遍歷:用一個visited數組標記所有訪問過的地方,遍歷圖,遇到第一個陸地且沒被訪問過,就用深搜遍歷此島嶼的全部陸地。

class Solution {
private:int dir[4][2] = {0, 1, 1, 0, -1, 0, 0, -1};void dfs(vector<vector<bool>>& visit, vector<vector<char>>& grid, int x, int y){for(int i = 0; i < 4; i++) {int nextx = x + dir[i][0];int nexty = y + dir[i][1];if(nextx < 0 || nextx >= grid.size() || nexty < 0 || nexty >= grid[0].size()) continue;if(!visit[nextx][nexty] && grid[nextx][nexty] == '1') {visit[nextx][nexty] = true;dfs(visit, grid, nextx, nexty);}}}
public:int numIslands(vector<vector<char>>& grid) {int n = grid.size(), m = grid[0].size();vector<vector<bool>> visit = vector<vector<bool>>(n, vector<bool>(m, false));int result = 0;for(int i = 0; i < n; i++) {for(int j = 0; j < m; j++) {if(!visit[i][j] && grid[i][j] == '1') {result++;visit[i][j] = true;dfs(visit, grid, i, j);}}}return result;}
};

994.腐爛的橘子BFS

在給定的 m x n 網格 grid 中,每個單元格可以有以下三個值之一:
值 0 代表空單元格;
值 1 代表新鮮橘子;
值 2 代表腐爛的橘子。
每分鐘,腐爛的橘子 周圍 4 個方向上相鄰 的新鮮橘子都會腐爛。
返回 直到單元格中沒有新鮮橘子為止所必須經過的最小分鐘數。如果不可能,返回 -1 。

class Solution {
public:int orangesRotting(vector<vector<int>>& grid) {int n = grid.size(), m = grid[0].size();queue<pair<int, int>> q;int fresh = 0;for(int i = 0; i < n; i++) {for(int j = 0; j < m; j++) {if(grid[i][j] == 2) {q.push({i,j});}else if(grid[i][j] == 1) {fresh++;}}}int time = 0;int dir[4][2] = {1, 0, 0, 1, -1, 0, 0, -1};while(!q.empty() && fresh > 0) {int size = q.size();while(size--) {auto [x, y] = q.front(); q.pop();for(int i = 0; i < 4;i++) {int nx = x + dir[i][0];int ny = y + dir[i][1];if(nx < 0 || ny < 0 || nx >= grid.size() || ny >= grid[0].size() || grid[nx][ny] != 1) continue;grid[nx][ny] = 2;q.push({nx,ny});fresh--;}}time++;}return fresh == 0 ? time : -1;}
};

207.課程表

你這個學期必須選修 numCourses 門課程,記為 0 到 numCourses - 1 。
在選修某些課程之前需要一些先修課程。 先修課程按數組 prerequisites 給出,其中 prerequisites[i] = [ai, bi] ,表示如果要學習課程 ai 則 必須 先學習課程 bi 。
例如,先修課程對 [0, 1] 表示:想要學習課程 0 ,你需要先完成課程 1 。
請你判斷是否可能完成所有課程的學習?如果可以,返回 true ;否則,返回 false 。

本題可約化為: 課程安排圖是否是 有向無環圖(DAG)。
方法一:入度表(廣度優先遍歷)
算法流程:
統計課程安排圖中每個節點的入度,生成 入度表 indegrees。
借助一個隊列 queue,將所有入度為 0 的節點入隊。
當 queue 非空時,依次將隊首節點出隊,在課程安排圖中刪除此節點 pre:
并不是真正從鄰接表中刪除此節點 pre,而是將此節點對應所有鄰接節點 cur 的入度 ?1,即 indegrees[cur] -= 1。
當入度 ?1后鄰接節點 cur 的入度為 0,說明 cur 所有的前驅節點已經被 “刪除”,此時將 cur 入隊。
在每次 pre 出隊時,執行 numCourses–;
若整個課程安排圖是有向無環圖(即可以安排),則所有節點一定都入隊并出隊過,即完成拓撲排序。換個角度說,若課程安排圖中存在環,一定有節點的入度始終不為 0。
因此,拓撲排序出隊次數等于課程個數,返回 numCourses == 0 判斷課程是否可以成功安排。

class Solution {
public:bool canFinish(int numCourses, vector<vector<int>>& prerequisites) {vector<vector<int>> adjacency(numCourses);vector<int> indegrees(numCourses, 0);queue<int> q;for(const auto& pair : prerequisites) {int course = pair[0], pre = pair[1];indegrees[course]++;adjacency[pre].push_back(course);}for(int i = 0; i < indegrees.size(); i++) {if(indegrees[i] == 0) q.push(i);}while(!q.empty()){int pre = q.front(); q.pop();numCourses--;for(int i = 0; i < adjacency[pre].size(); i++) {if(--indegrees[adjacency[pre][i]] == 0)q.push(adjacency[pre][i]);}}return numCourses == 0;}
};

208.前綴樹

Trie(發音類似 “try”)或者說 前綴樹 是一種樹形數據結構,用于高效地存儲和檢索字符串數據集中的鍵。這一數據結構有相當多的應用情景,例如自動補全和拼寫檢查。
請你實現 Trie 類:
Trie() 初始化前綴樹對象。
void insert(String word) 向前綴樹中插入字符串 word 。
boolean search(String word) 如果字符串 word 在前綴樹中,返回 true(即,在檢索之前已經插入);否則,返回 false 。
boolean startsWith(String prefix) 如果之前已經插入的字符串 word 的前綴之一為 prefix ,返回 true ;否則,返回 false 。路漫漫我不畏;

class Trie {
private:bool isEnd;Trie* next[26];
public:Trie() {isEnd = false;memset(next, 0, sizeof(next));}void insert(string word) {Trie* node = this;for(char ch : word){if(node->next[ch - 'a'] == NULL) {node->next[ch - 'a'] = new Trie();}node = node->next[ch - 'a'];}node->isEnd = true;}bool search(string word) {Trie* node = this;for(char ch : word) {node = node->next[ch - 'a'];if(node == NULL) return false;}return node->isEnd;}bool startsWith(string prefix) {Trie* node = this;for(char ch : prefix) {node = node->next[ch - 'a'];if(node == NULL) return false;}return true;}
};/*** Your Trie object will be instanti`ated and called as such:* Trie* obj = new Trie();* obj->insert(word);* bool param_2 = obj->search(word);* bool param_3 = obj->startsWith(prefix);*/

全排列

46. 全排列

給定一個不含重復數字的數組 nums ,返回其 所有可能的全排列 。你可以 按任意順序 返回答案。
在這里插入圖片描述

class Solution {
private:vector<int> path;vector<vector<int>> result;void backtracking(vector<int> & nums, vector<bool>& used){if(path.size() == nums.size()) {result.push_back(path);return;}for(int i = 0; i < nums.size(); i++){if(used[i] == true) continue;path.push_back(nums[i]);used[i] = true;backtracking(nums, used);used[i] = false;path.pop_back();}}
public:vector<vector<int>> permute(vector<int>& nums) {path.clear();result.clear();vector<bool> used(nums.size(), false);backtracking(nums,used);return result;}
};

78.子集

給你一個整數數組 nums ,數組中的元素 互不相同 。返回該數組所有可能的子集(冪集)。
在這里插入圖片描述
子集問題、組合問題、分割問題可以抽象成樹,組合和分割是收集樹的葉子結點,而子集是找樹的所有結點。

class Solution {
public:vector<int> path;vector<vector<int>> result;void backtracking(vector<int>& nums, int startIndex)  {result.push_back(path);for(int i = startIndex; i < nums.size(); i++) {path.push_back(nums[i]);backtracking(nums, i + 1);path.pop_back();}}vector<vector<int>> subsets(vector<int>& nums) {backtracking(nums, 0);return result;}
};

17. 電話號碼的字母組合

給定一個僅包含數字 2-9 的字符串,返回所有它能表示的字母組合。答案可以按 任意順序 返回。
在這里插入圖片描述

class Solution {
private:const string letterMap[10] = {"","","abc","def","ghi","jkl","mno","pqrs","tuv","wxyz"};
public:vector<string> result;string s;void backtracking(const string& digits, int index) {if(digits.size() == index) {result.push_back(s);return;}int digit = digits[index] - '0';string letter = letterMap[digit];for(int i = 0; i < letter.size(); i++){s.push_back(letter[i]);backtracking(digits, index + 1);s.pop_back();}}vector<string> letterCombinations(string digits) {s.clear();result.clear();if(digits.size() == 0)return result;backtracking(digits, 0);return result;}
};

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/81573.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/81573.shtml
英文地址,請注明出處:http://en.pswp.cn/web/81573.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

真實網絡項目中交換機常用的配置與解析

一、配置三層鏈路聚合增加鏈路帶寬 1.組網需求 某企業有多個部門分布在不同的地區&#xff0c;由于業務發展的需要&#xff0c;不同區域的部門與部門之間有進行帶有VLAN Tag的報文的傳輸需求。采用透明網橋的遠程橋接和QinQ功能&#xff0c;可以實現企業在不同區域部門之間進…

【Redis】過期鍵刪除策略,LRU和LFU在redis中的實現,緩存與數據庫雙寫一致性問題,go案例

一、Redis 中的過期鍵刪除策略有哪些&#xff1f; 采用了 惰性刪除 和 定期刪除 兩種策略處理過期鍵&#xff1a; 1. 惰性刪除&#xff08;Lazy Deletion&#xff09; 機制&#xff1a;只有在訪問 key 時才檢查是否過期&#xff0c;如果已過期則立刻刪除。優點&#xff1a;對…

為什么單張表索引數量建議控制在 6 個以內

單張表索引數量建議控制在6個以內的主要原因包括以下幾點?&#xff1a; ?性能影響?&#xff1a;索引會占用額外的磁盤空間。如果索引數量過多&#xff0c;會占用大量的磁盤空間&#xff0c;尤其是在數據量較大的情況下&#xff0c;索引占用的空間可能會超過數據本身。此外&…

深度學習實戰109-智能醫療隨訪與健康管理系統:基于Qwen3(32B)、LangChain框架、MCP協議和RAG技術研發

大家好,我是微學AI,今天給大家介紹一下深度學習實戰109-智能醫療隨訪與健康管理系統:基于Qwen3(32B)、LangChain框架、MCP協議和RAG技術研發。在當今醫療信息化快速發展的背景下,醫療隨訪與健康管理面臨著數據分散、信息整合困難、個性化方案生成效率低等挑戰。傳統的醫療隨…

聊一聊 .NET Dump 中的 Linux信號機制

一&#xff1a;背景 1. 講故事 當 .NET程序 在Linux上崩潰時&#xff0c;我們可以配置一些參考拿到對應程序的core文件&#xff0c;拿到core文件后用windbg打開&#xff0c;往往會看到這樣的一句信息 Signal SIGABRT code SI_USER (Sent by kill, sigsend, raise)&#xff0c…

如何在uniapp H5中實現路由守衛

目錄 Vue3 app.config.globalProperties 1. 創建 Vue 應用實例 2. 添加全局屬性或方法 3. 在組件中使用全局屬性或方法 beforeEach在uniapp的注冊 1、在H5中這兩個對象是都存在的。「router:route」但是功能并不全面,具體可參考下圖。 2、剛剛測試了一下,在微信小程序…

無人機降落傘設計要點難點及原理!

一、設計要點 1. 傘體結構與折疊方式 傘體需采用輕量化且高強度的材料&#xff08;如抗撕裂尼龍或芳綸纖維&#xff09;&#xff0c;并通過多重折疊設計&#xff08;如三重折疊縫合&#xff09;減少展開時的阻力&#xff0c;同時增強局部承力區域的強度。 傘衣的幾何參數&am…

AI時代新詞-AI增強現實(AI - Enhanced Reality)

一、什么是AI增強現實&#xff08;AI - Enhanced Reality&#xff09;&#xff1f; AI增強現實&#xff08;AI - Enhanced Reality&#xff09;是指將人工智能&#xff08;AI&#xff09;技術與增強現實&#xff08;Augmented Reality&#xff0c;簡稱AR&#xff09;技術相結合…

基于Matlab實現各種光譜數據預處理

在IT領域&#xff0c;尤其是在數據分析和科學研究中&#xff0c;光譜數據的預處理是至關重要的步驟。光譜數據通常包含了豐富的信息&#xff0c;但往往受到噪聲、雜散光、背景信號等因素的影響&#xff0c;需要通過預處理來提取有效信號&#xff0c;提高分析的準確性和可靠性。…

用 commitizen-go 來實現標準化你的Git提交信息 【windows 版】

前言 團隊中有部分人的 commit 信息比較隨意&#xff0c;因此想用工具來進行約束&#xff0c; web 項目可以使用 commitizen 來實現&#xff0c; 但是 golang 又該用什么來約束呢&#xff0c; 在 Github 上找到 commitizen-go 可以做為 commitizen 平替&#xff0c;但該說明文…

為什么共現矩陣是高維稀疏的

為什么共現矩陣是高維稀疏的&#xff1f; 共現矩陣&#xff08;Co-occurrence Matrix&#xff09;的高維稀疏性是其固有特性&#xff0c;主要由以下原因導致&#xff1a; 1. 高維性的根本原因 詞匯表大小決定維度&#xff1a; 共現矩陣的維度為 ( V \times V )&#xff0c;其…

OpenLayers 加載鼠標位置控件

注&#xff1a;當前使用的是 ol 5.3.0 版本&#xff0c;天地圖使用的key請到天地圖官網申請&#xff0c;并替換為自己的key 地圖控件是一些用來與地圖進行簡單交互的工具&#xff0c;地圖庫預先封裝好&#xff0c;可以供開發者直接使用。OpenLayers具有大部分常用的控件&#x…

知識宇宙-學習篇:學編程為什么從C語言開始學起?

名人說&#xff1a;博觀而約取&#xff0c;厚積而薄發。——蘇軾《稼說送張琥》 創作者&#xff1a;Code_流蘇(CSDN)&#xff08;一個喜歡古詩詞和編程的Coder&#x1f60a;&#xff09; 目錄 一、C語言的歷史地位與影響力1. 編程語言的"鼻祖"2. 現代技術的基礎 二、…

手機IP地址更換的影響與操作指南

在移動互聯網時代&#xff0c;IP地址如同手機的“網絡身份證”&#xff0c;其變更可能對上網體驗、隱私安全及服務訪問產生連鎖反應。無論是為了繞過地域限制、保護隱私&#xff0c;還是解決網絡沖突&#xff0c;了解IP更換的影響與正確操作方法都至關重要。本文將系統分析影響…

基于Alibaba Cloud Linux + 寶塔面板安裝 LibreOffice 全攻略流程

LibreOffice 是一款功能強大的辦公軟件,默認使用開放文檔格式 (OpenDocument Format , ODF), 并支持 *.docx, *.xlsx, *.pptx 等其他格式。 官網:https://www.libreoffice.org/ 或 https://zh-cn.libreoffice.org/ Alibaba Cloud Linux 3(Soaring Falcon) 是阿里云自主研發…

UniApp 微信小程序綁定動態樣式 :style 避坑指南

在使用 UniApp 開發跨端應用時&#xff0c;綁定動態樣式 :style 是非常常見的操作。然而&#xff0c;很多開發者在編譯為 微信小程序 時會遇到一個奇怪的問題&#xff1a; 原本在 H5 中可以正常渲染的樣式&#xff0c;在微信小程序中卻不生效&#xff01; 讓我們通過一個示例來…

WebSocket學習總結

WebSocket 是一種基于TCP的網絡通信協議&#xff0c;允許瀏覽器和服務器之間進行全雙工、實時、低延遲的雙向數據傳輸。它突破了傳統HTTP協議的限制&#xff08;請求-響應模式&#xff09;&#xff0c;特別適合需要實時通信的場景&#xff08;如聊天、實時數據推送、游戲等&…

【screen-recorder-tts】RPG 游戲字幕語音實時合成,讓無聲文字游戲變有聲

screen-recorder-tts RPG 游戲字幕語音實時合成&#xff0c;讓無聲文字游戲變有聲&#xff01; 歡迎大佬們提 PR&#xff0c;一起完善這個項目&#xff01;&#xff01;&#xff01; Real-time TTS for RPG game subtitles, turning silent text games into audio experienc…

深入解析Spring Boot與Redis的緩存集成實踐

深入解析Spring Boot與Redis的緩存集成實踐 引言 在現代Web應用中&#xff0c;緩存技術是提升系統性能的重要手段之一。Redis作為一種高性能的內存數據庫&#xff0c;廣泛應用于緩存場景。本文將詳細介紹如何在Spring Boot項目中集成Redis&#xff0c;并探討其在實際開發中的…

4月報 | SeaTunnel支持TDengine的多表Sink功能

各位熱愛 Apache SeaTunnel 的小伙伴們&#xff0c;今年 4 月份月報更新啦&#xff01;這里將記錄 SeaTunnel 社區每月的重要更新&#xff0c;歡迎關注&#xff01; 在本月的眾多更新中&#xff0c;最令人關注的一項新特性是——TDengine 多表 Sink 功能的支持&#xff08;由 …