LeetCode热题100刷题15:200. 岛屿数量、所有可达路径、118. 杨辉三角、287. 寻找重复数、84. 柱状图中最大的矩形

200. 岛屿数量

借助DFS寻找整个图的连通分量数,DFS将一个连通分量中的节点标记为visited,res记录连通分量数,最后返回res

class Solution {
public:const int dir[4][2] = {1,0,0,1,-1,0,0,-1};void dfs(vector<vector<char>>& grid,vector<vector<bool>>& visited,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;else if(!visited[nextx][nexty] && grid[nextx][nexty]=='1') {visited[nextx][nexty]=true;dfs(grid,visited,nextx,nexty);} }}int numIslands(vector<vector<char>>& grid) {int res = 0;vector<vector<bool>> visited(grid.size(),vector<bool>(grid[0].size(),0));for(int i=0;i<grid.size();i++) {for(int j=0;j<grid[0].size();j++) {if(!visited[i][j] && grid[i][j]=='1') {res++;visited[i][j]=true;dfs(grid,visited,i,j);}}}return res;}
};

(图论,深度优先搜索DFS复习)

98. 所有可达路径

**加粗样式**

#include <bits/stdc++.h>
using namespace std;vector<int> path;
vector<vector<int>> res;void dfs(const vector<vector<int>>& grid, int x, int n) {if(x==n) {res.push_back(path);return;}for(int i=1;i<=n;i++) {if(grid[x][i]==1) {path.push_back(i);dfs(grid,i,n);path.pop_back();}}
}
int main() {int n,m;cin>>n>>m;std::vector<vector<int>> grid(n+1,vector<int>(n+1,0));for(int i=1;i<=m;i++) {int a,b;cin>>a>>b;grid[a][b]=1;}path.push_back(1);dfs(grid,1,n);if(res.size()==0)cout<<-1<<endl;for(vector<int> pa : res) {for(int i=0;i<pa.size()-1;i++) {cout<<pa[i]<<" ";}cout<<pa[pa.size()-1]<<endl;}
}

118. 杨辉三角

res就当作是dp数组,找res[i][j]的更新规则,
样例中给出每一层的数组长度等于元素的个数,下标i从0开始,各层的长度需要resize为i+1

class Solution {
public:vector<vector<int>> generate(int numRows) {vector<vector<int>> res(numRows);for(int i=0;i<numRows;i++) {res[i].resize(i+1);res[i][0] = res[i][i] = 1;for(int j=1;j<i;j++) {res[i][j] = res[i-1][j]+res[i-1][j-1];}}return res;}
};

287. 寻找重复数

看作是一个数组找“环”的起点的题

class Solution {
public:int findDuplicate(vector<int>& nums) {if(nums.size()==1)return nums[0];int slow = nums[0],fast = nums[nums[0]];while(slow!=fast) {slow = nums[slow];fast = nums[nums[fast]];}slow = 0;while(slow != fast) {slow = nums[slow];fast = nums[fast];}return slow;}
};

84. 柱状图中最大的矩形

class Solution {
public:int largestRectangleArea(vector<int>& heights) {if(heights.size()==0)return 0;if(heights.size()==1)return heights[0];heights.insert(heights.begin(), 0);heights.push_back(0);stack<int> stk;int res=0;stk.push(0);for(int i=1;i<heights.size();i++) {if(heights[i] > heights[stk.top()]) {stk.push(i);}else if(heights[i] == heights[stk.top()]) {stk.pop();stk.push(i);}else {while(!stk.empty() && heights[i] < heights[stk.top()]) {int mid = stk.top();stk.pop();if(!stk.empty()) {int left = stk.top();int w = i-left-1;res = max(res,w*heights[mid]);}}stk.push(i);}}return res;}
};

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

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

相关文章

云WAF如何帮助政府网络进行安全防御

云WAF的基本功能和作用 云WAF&#xff08;Cloud Web Application Firewall&#xff09;是一种基于云计算的Web应用防火墙服务&#xff0c;它能够实时监测并分析网络流量&#xff0c;自动识别并阻止恶意请求&#xff0c;包括但不限于SQL注入、XSS跨站脚本攻击、命令注入、非法文…

代码随想录——不同路径Ⅱ(Leetcode 63)

题目链接 动态规划 class Solution {public int uniquePathsWithObstacles(int[][] obstacleGrid) {int m obstacleGrid.length;int n obstacleGrid[0].length;int[][] dp new int[m][n];// 遇到障碍则从(0,0)到达for(int i 0; i < m && obstacleGrid[i][0] …

前端挑战:Tkinter布局与设计【三种布局】

前端挑战:Tkinter布局与设计【三种布局】 文章目录 前端挑战:Tkinter布局与设计【三种布局】前言Frame 窗口组件代码效果Tkinter的布局grid 网格布局效果展示:代码讲解pack 布局基本使用左右布局place 布局代码预览前言 作为一个前端开发,习惯性的用HTML去解决客户端的问题…

2024.7.14周报

目录 摘要 ABSTRACT 一、文献阅读 一、题目 二、摘要 三、文献解读 一、Introduction 二、KINN框架 三、主要结果 四、Conclusion 二、KAN 一、KAN与MLP区别 二、KAN网络解析 三、激活函数参数化&#xff08;B-splines&#xff09; 三、网络架构代码 摘要 本周…

Kafka基础入门篇(深度好文)

Kafka简介 Kafka 是一个高吞吐量的分布式的基于发布/订阅模式的消息队列&#xff08;Message Queue&#xff09;&#xff0c;主要应用与大数据实时处理领域。 1. 以时间复杂度为O(1)的方式提供消息持久化能力。 2. 高吞吐率。&#xff08;Kafka 的吞吐量是MySQL 吞吐量的30…

社交网络图数据集

Stanford Large Network Dataset Collection 斯坦福大学大型网络数据集 官方网站&#xff1a;https://snap.stanford.edu/data/ the University of Florida Sparse Matrix Collection 佛罗里达大学稀疏矩阵集合 官方网站&#xff1a;https://sparse.tamu.edu/ 1、com…

Spring源码(三) Spring IoC之BeanFactory创建bean和获取bean

ApplicationContext 和 BeanFactory 可以先简单了解下 ApplicationContext 和 BeanFactory。 详情见&#xff1a; https://blog.csdn.net/sinat_32502451/article/details/140247662 getBean() 代码示例 首先看代码示例&#xff0c;调试一下。 代码详情见&#xff1a; htt…

输入法发展历史

输入法的发展历史&#xff0c;尤其是中文输入法&#xff0c;是一个相当丰富和多元的话题&#xff0c;它反映了技术进步、用户需求变化以及计算机和移动设备界面设计的演进。以下是一个概览&#xff1a; 早期阶段 1970s&#xff1a;朱邦复在1976年发明了仓颉输入法&#xff0c;…

python:绘制一元四次函数的曲线

编写 test_x4_x2_4x.py 如下 # -*- coding: utf-8 -*- """ 绘制函数 y x^4x^24x-3 在 -2<x<2 的曲线 """ import numpy as np from matplotlib import pyplot as plt# 用于正常显示中文标题&#xff0c;负号 plt.rcParams[font.sans-s…

Amazon EC2 部署Ollama + webUI

最近和同事闲聊&#xff0c;我们能不能内网自己部署一个LLM&#xff0c;于是便有了Ollama webUI的尝试 对于Linux&#xff0c;使用一行命令即可 curl -fsSL https://ollama.com/install.sh | shollama --help Large language model runnerUsage:ollam…

网络规划设计师教程(第二版) pdf

网络规划设计师教程在网上找了很多都是第一版&#xff0c;没有第二版。 所以去淘宝买了第二版的pdf&#xff0c;与其自己独享不如共享出来&#xff0c;让大家也能看到。 而且这个pdf我已经用WPS扫描件识别过了&#xff0c;可以直接CtrlF搜索关键词&#xff0c;方便查阅。 链接…

element-ui 表格固定头和固定列表格错位

问题&#xff1a;当 el-table 组件固定了表头和列时&#xff0c;列表数据触发滚动条&#xff0c;列表滚动到底&#xff0c;会有错位。 原因分析&#xff1a;因为固定列和固定表头产生的滚动条宽度不一致&#xff0c;导致有轻微误差。 解决&#xff1a;自定义滚动条高度&#…

PostgreSQL 中如何解决因频繁的小事务导致的性能下降?

&#x1f345;关注博主&#x1f397;️ 带你畅游技术世界&#xff0c;不错过每一次成长机会&#xff01;&#x1f4da;领书&#xff1a;PostgreSQL 入门到精通.pdf 文章目录 PostgreSQL 中解决因频繁小事务导致性能下降的方法 PostgreSQL 中解决因频繁小事务导致性能下降的方法…

搭建调用链监控Zipkin和Sleuth

项目环境: win7、jdk8 1、添加依赖,添加了spring-cloud-starter-zipkin会自动导入Sleuth <!--Sleuth,zipkin--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-zipkin</artifactId><ve…

nodejs实现数据库备份、清空表、删除表

备份数据库 使用 mysqldump 库&#xff0c;实现数据备份 var path require(path) var fs require(fs) const mysqldump require(mysqldump)const backupsMysql () > {const backupFolder path.join(__dirname, backup)if (!fs.existsSync(backupFolder)) {fs.mkdirSync…

基于SpringBoot的校园志愿者管理系统

你好呀&#xff0c;我是计算机学姐码农小野&#xff01;如果有相关需求&#xff0c;可以私信联系我。 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SpringBoot框架 工具&#xff1a;MyEclipse、Tomcat 系统展示 首页 个人中心 志愿者管理 活动信息…

Python + Playwright(20):模拟手机设备

Python + Playwright(20):模拟手机设备 前言为什么要模拟手机设备?使用Playwright模拟手机设备(基础示例)使用Playwright模拟手机设备(复杂示例)进阶配置和技巧自定义设备配置:模拟特定的屏幕尺寸移动设备性能测试测量页面加载时间模拟不同的网络条件总结前言 在UI自动…

【每日一练】python函数与装饰器

Python装饰器是一种用于修改函数或类的行为的语法结构。装饰器可以在不修改原始函数或类的情况下&#xff0c;为它们添加额外的功能。 使用装饰器的常见场景是在不改变原函数代码的情况下&#xff0c;给函数添加日志记录、性能统计、输入验证等功能。装饰器还可以用于授权、缓…

SQL性能下降的原因

一、SQL性能下降的原因 主要是性能下降SQL慢、执行时间长、等待时间长 不是一条SQL抓出来就要优化&#xff0c;在真实的生产环境下这种故障第一个要去复线&#xff0c;有可能去排查的时候没&#xff0c;所以没法复线。 可能需要它跑半天或者一天来缩小筛查的范围&#xff0c…

ThingsBoard本地windows环境启动

提示&#xff1a;以下内容只是本人自己在环境运行情况&#xff0c;不同环境或许会有区别请注意甄别 本地部署 前言简介正文实现总结 前言 前置环境的配置&#xff0c;首先电脑需要配置了git、maven、JDK17 本人使用的maven版本号为3.8.4 软件版本号git2.42.0maven3.8.4jdk17n…