当前位置: 首页 > news >正文

力扣hot100——图论

200. 岛屿数量

class Solution {
public:int numIslands(vector<vector<char>>& grid) {int ans = 0;vector<int> dx = { 0, 1, 0, -1 };vector<int> dy = { 1, 0, -1, 0 };int n = grid.size(), m = grid[0].size();vector<vector<int>> vis(n, vector<int>(m, 0));auto dfs = [&](this auto&& dfs, int x, int y) -> void {vis[x][y] = 1;for (int i = 0; i < 4; i++) {int tx = x + dx[i];int ty = y + dy[i];if (tx < 0 || ty < 0 || tx >= n || ty >= m) continue;if (grid[tx][ty] == '0' || vis[tx][ty]) continue;dfs(tx, ty);}};for (int i = 0; i < n; i++) {for (int j = 0; j < m; j++) {if (!vis[i][j] && grid[i][j] == '1') {dfs(i, j);ans++;}}}return ans;}
};

 dfs求连通块

994. 腐烂的橘子 

class Solution {
public:int orangesRotting(vector<vector<int>>& a) {vector<int> dx = { 0, 1, 0, -1 };vector<int> dy = { 1, 0, -1, 0 };int n = a.size(), m = a[0].size();vector<vector<int>> vis(n, vector<int>(m, 0));queue <pair<int, int>> q;for (int i = 0; i < n; i++) {for (int j = 0; j < m; j++) {if (a[i][j] == 2) q.push({ i, j });}}int ans = 0;while (q.size()) {if (q.size()) ans++;vector<pair<int, int>> v;while (q.size()) {auto [x, y] = q.front();q.pop();vis[x][y] = 1;v.push_back({x, y});}for (auto [x, y] : v) {for (int i = 0; i < 4; i++) {int tx = x + dx[i], ty = y + dy[i];if (tx < 0 || ty < 0 || tx >= n || ty >= m) continue;if (vis[tx][ty] || a[tx][ty] != 1) continue;q.push({tx, ty});}}}for (int i = 0; i < n; i++) {for (int j = 0; j < m; j++) {if (a[i][j] == 1 && !vis[i][j]) return -1;}}return max(ans - 1, 0);}
};

bfs

207. 课程表 

class Solution {
public:bool canFinish(int n, vector<vector<int>>& a) {vector<vector<int>> e(n);vector<int> deg(n, 0);for (int i = 0; i < a.size(); i++) {int x = a[i][0], y = a[i][1];e[x].push_back(y);deg[y]++;}int cnt = 0;queue<int> q;for (int i = 0; i < n; i++) {if (!deg[i]) q.push(i);}while (q.size()) {auto u = q.front();q.pop();cnt++;for (auto v : e[u]) {deg[v]--;if (!deg[v]) q.push(v);}}return cnt == n;}
};

拓扑排序

 208. 实现 Trie (前缀树)

class Trie {
public:int idx;vector<vector<int>> tr;vector<int> cnt;Trie() {idx = 0;tr.resize(1e5, vector<int>(26, 0));cnt.resize(1e5, 0);}void insert(string word) {int p = 0;for (auto ch : word) {int t = ch - 'a';if (!tr[p][t]) tr[p][t] = ++idx;p = tr[p][t];}cnt[p]++;}bool search(string word) {int p = 0;for (auto ch : word) {int t = ch - 'a';if (!tr[p][t]) return false;p = tr[p][t];}return cnt[p];}bool startsWith(string prefix) {int p = 0;for (auto ch : prefix) {int t = ch - 'a';if (!tr[p][t]) return false;p = tr[p][t];}return true;}
};

字典树,注意节点不为0不代表有这个前缀

然后注意tr数组一维的大小

http://www.lryc.cn/news/514210.html

相关文章:

  • Docker- Unable to find image “hello-world“locally
  • spring-boot启动源码分析(二)之SpringApplicationRunListener
  • ELK入门教程(超详细)
  • 人工智能知识分享第六天-机器学习_​逻辑回归(Logistic Regression)
  • 基于Springboot + vue实现的校园周边美食探索及分享平台
  • 初学STM32 --- 外部SRAM
  • 创龙3588——debian根文件系统制作
  • javacript中function (res) {}与箭头函数表达式(res) =>{}的区别
  • kylin安装docker
  • 【Yarn】通过JMX采集yarn相关指标的Flink任务核心逻辑
  • 鸿蒙HarmonyOS开发:基于Swiper组件和自定义指示器实现多图片进度条轮播功能
  • Excel 身份证号计算年龄
  • 【2024年-6月-14日-开源社区openEuler实践记录】探索 test - tools:高效测试的开源宝库
  • 2022浙江大学信号与系统笔记
  • DeepSeek-VL2
  • 前端⾯试⼋股⽂
  • 【Rust自学】8.6. HashMap Pt.2:更新HashMap
  • Python异常处理详解:概念、语法与实践
  • Kotlin在医疗大健康域的应用实例探究与编程剖析(上)
  • QT----------QT Data Visualzation
  • 什么是Sight Words(信号词)
  • SpringBoot日志快速集成详解-生产实战
  • 路由技术在网络中的作用及特点
  • 【Python系列】Flask 与 FastAPI:两个 Python Web 框架的对比分析
  • 云手机:虚拟技术的革命性应用与实体手机的优劣对比
  • 3. C语言 数据类型
  • npm install 安装选项 -d -s -g
  • pdf预览兼容问题- chrome浏览器105及一下预览不了
  • 【可实战】需求分析-测试计划↓-测试设计-测试执行-测试总结↓(包含测试计划、测试总结模板,以公司要求为准)
  • MySQL 03 章——基本的SELECT语句