代码随想录算法训练营第五十九天|503.下一个更大元素II 42. 接雨水

news2024/11/19 18:44:49

目录

LeeCode 503.下一个更大元素II 

LeeCode 42. 接雨水

暴力解法

优化双指针法

单调栈法


LeeCode 503.下一个更大元素II 

503. 下一个更大元素 II - 力扣(LeetCode)

【思路】 

相较于前两道题目,这道题目将数组改为循环数组,思路与之前大致相同。

【代码】

class Solution {
public:
    vector<int> nextGreaterElements(vector<int>& nums) {
    	vector<int> result(nums.size(), -1);
		if (nums.size() == 0) return result;
		stack<int> st;
		st.push(0);
		for (int i = 0; i < nums.size() * 2; i++) {
			if (nums[i % nums.size()] <= nums[st.top()]) st.push(i % nums.size());
			else {
				while (!st.empty() && nums[i % nums.size()] > nums[st.top()]) {
					result[st.top()] = nums[i % nums.size()];
					st.pop();
				}
				st.push(i % nums.size());
			}
		}  
		return result;
    }
};

LeeCode 42. 接雨水

42. 接雨水 - 力扣(LeetCode)

暴力解法

【思路】

按列计算,每一列雨水的高度 = min(左侧最高柱子的高度, 右侧最高柱子的高度) - 该列柱子高度;从头遍历所有列,首尾的柱子不接水。如下图所示。

 【代码】

class Solution {
public:
    int trap(vector<int>& height) {
    	int sum = 0;
    	for (int i = 0; i < height.size(); i++) {
    		if (i == 0 || i == height.size() - 1) continue;
    		int rheight = height[i];
    		int lheight = height[i];
    		for (int r = i + 1; r < height.size(); r++) {
    			if (height[r] > rheight) rheight = height[r];
			}
			for (int l = i - 1; l >= 0; l--) {
    			if (height[l] > lheight) lheight = height[l];
			}
			int h = min(lheight, rheight) - height[i];
			if (h > 0) sum += h;
		}
        return sum;
    }
};

时间复杂度:O(n²)                                              空间复杂度:O(1) 

优化双指针法

【思路】

使用双指针遍历,把每一个位置的左边最高高度和右边最高高度分别记录在数组上; 从左向右遍历:maxLeft[i] = max(height[i], maxLeft[i - 1]); 从右向左遍历:maxRight[i] = max(height[i], maxRight[i + 1]);

【代码】

class Solution {
public:
    int trap(vector<int>& height) {
    	if (height.size() <= 2) return 0;;
    	vector<int> maxleft(height.size(), 0);
    	vector<int> maxright(height.size(), 0);
    	int size = maxright.size();
    	maxleft[0] = height[0];
    	for (int i = 1; i < size; i++) {
    		maxleft[i] = max(height[i], maxleft[i - 1]);
		}
		maxright[size - 1] = height[size - 1];
		for (int i = size - 2; i >= 0; i--) {
			maxright[i] = max(height[i], maxright[i + 1]);
		}
		int sum = 0;
		for (int i = 0; i < size; i++) {
			int count = min(maxleft[i], maxright[i]) - height[i];
			if (count > 0) sum += count; 
		}
		return sum;
    }
};

单调栈法

【思路】

按行计算,从栈顶到栈底递增,柱子高度大于栈顶元素时出现凹槽,栈顶元素为凹槽底部的柱子,栈顶第二个元素是凹槽左边的柱子,添加的元素是凹槽右边的柱子。遇到高度相同的柱子时,更新下标,用最右边的柱子来计算宽度。栈内存储柱子的下标,对应的高度即为height[stack.top()]。

 【代码】

class Solution {
public:
    int trap(vector<int>& height) {
    	stack<int> st;
    	int sum = 0;
    	st.push(0);
    	for (int i = 1; i < height.size(); i++) {
    		while(!st.empty() && height[i] > height[st.top()]) {
    			int mid = st.top();
    			st.pop();
    			if (!st.empty()) {
                    //求雨水高度
    				int h = min(height[st.top()], height[i]) - height[mid];
                    //求雨水宽度
    				int w = i - st.top() - 1;
    				sum += h * w;
				}
			}
			st.push(i);
		}
		return sum;
    }
};

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

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

相关文章

python获取度娘热搜数据并保存成Excel

python获取百度热搜数据 一、获取目标、准备工作二、开始编码三、总结 一、获取目标、准备工作 1、获取目标&#xff1a; 本次获取教程目标&#xff1a;某度热搜 2、准备工作 环境python3.xrequestspandas requests跟pandas为本次教程所需的库&#xff0c;requests用于模拟h…

在读博士怎么申请公派访学?

作为在读博士生&#xff0c;申请公派访学是一项重要而有益的经历。下面知识人网将为您介绍一些关于如何申请公派访学的步骤和注意事项。 首先&#xff0c;您需要找到一个合适的公派访学机会。可以通过与导师、教授或其他相关人士进行交流来获取相关信息。还可以参考学术会议、研…

【Linux】linux | 服务响应慢、问题排查 | 带宽问题导致

一、说明 1、项目使用云服务器&#xff0c;服务器配置&#xff1a;5M带宽、4核、32G&#xff0c;1T&#xff0c;CentOS7 2、CPU、内存、磁盘IO都没有达到瓶颈&#xff0c;猜测是带宽问题 3、应用比较多&#xff0c;应用中间件&#xff0c;十几个差不多 4、同时在线人数30 5、已…

继承~~~

1&#xff1a;继承概述&#xff0c;使用继承的好处 1&#xff1a;什么是继承&#xff1f; Java中提供一个关键字extends&#xff0c;用这个关键字&#xff0c;我们可以让一个类和另一类建立起父子关系。 public class Student extends People{} Student称为子类&#xff08…

乘势而起:机载航电·显控显示系统仿真

改革开放以来&#xff0c;我国国民经济与科学技术取得了长足的发展&#xff0c;信息化、工业成熟度与自动化程度不断深化&#xff0c;极大地增强了国家的综合实力、在世界范围内显示了大国地位。在当前科技产业的发展和变革的历史性交汇期&#xff0c;“工业4.0”、“中国制造2…

iOS App 上架流程图文教学

在上架App 之前必须先准备好开发者帐号&#xff0c;但申请开发者帐号因法兰克早在之前已经申请好了&#xff0c;故就跳过此步骤&#xff0c;直接从产生凭证到上传App开始讲起。首先&#xff0c;要将自己辛苦写好的App 送审的话&#xff0c;则要依序做完下列几件事情即可。 在开…

NFT Insider #98:The Sandbox与Forkast Labs 达成合作,苹果的混合现实头显将增强游戏和元宇宙

引言&#xff1a;NFT Insider由NFT收藏组织WHALE Members(https://twitter.com/WHALEMembers)、BeepCrypto&#xff08;https://twitter.com/beep_crypto&#xff09;联合出品&#xff0c;浓缩每周NFT新闻&#xff0c;为大家带来关于NFT最全面、最新鲜、最有价值的讯息。每期周…

对称加密DES加密算法原理、用户登录应用案例分享

更多知识 学习&#xff1a;https://www.processon.com/view/60504b5ff346fb348a93b4fa#map 目录&#xff1a; DES算法的工作原理DES算法的优点DES算法的缺点DES算法的应用场景DES算法性能分析用户登录实例总结 1. DES算法的工作原理 DES算法是一种对称加密算法&#xff0c;使…

定向写作模型CTRL,Conditional Transformer Language有条件的文本生成模型

定向写作模型CTRL 介绍 CTRL全称为Conditional Transformer Language有条件的文本生成模型&#xff0c;它始于Salesforce在2019年发布的论文《A Conditional Transformer Language Model for Controllable Generation》&#xff0c;该模型用于定向写作。论文地址如下&#xff…

双功能螯合剂:1777804-45-1,DOTA-(COOt-Bu)3-CH2-Ph-azide,的反应特点及其参数说明

​ 中文名称&#xff1a;1,1-二甲基乙基4-[(4-叠氮苯基)甲基] -7,10-双[2-(1,1-二甲基乙氧基) -2-氧乙基] -1,4,7,10-四氮杂环十二烷 -1-乙酸酯 英文名称&#xff1a;DOTA-(COOt-Bu)3-CH2-Ph-azide&#xff0c;DOTA-(COOt-Bu)3-CH2-Ph-N3 规格标准&#xff1a;1g、5g、10g CAS…

【电源设计】18650电池电源串并联设计——改变电压或容量

有时我们有需要改造电池电源的需要&#xff0c;比如增大容量&#xff0c;增大电压之类的&#xff0c;本文介绍18650锂电池&#xff0c;以及如何用18650锂电池串并联设计电源&#xff0c;达到增大容量或者增大电压的效果&#xff1a; 目录 一、18650锂电池基本知识&#xff1a…

腾讯的基础认证适合没经验、没专业知识的人吗?

IT行业可以说是现在最热门的行业之一了&#xff0c;很多人都会选择报考这个专业&#xff0c;同时还有很多没有基础的人&#xff0c;也会选择在毕业后继续教育&#xff0c;从而获得进入这一行的机会&#xff0c;可以说每个人都在内卷&#xff0c;技术和证书都需要拥有&#xff0…

这就是实力!京东资深架构师用实例详解Java虚拟机(源码剖析)

前言 Java是一门流行多年的高级编程语言&#xff0c;与其相关的就业岗位很多&#xff0c;但是最近几年却出现了用人单位招不到合适的人&#xff0c;而大量Java程序员找不到工作的尴尬局面。究其根本原因是岗位对Java开发技术的要求高&#xff0c;不但要会应用&#xff0c;而且…

祛除红眼算法python实现

最近研究了一下祛除红眼的算法&#xff0c;主要的思想都是将RGB通道里面的R通道给想法设法的降低&#xff0c;其他的通道稍微进行变换就行&#xff0c;这里使用python运行了一下例子看看&#xff0c; version2参考了代码&#xff1a;https://www.cnblogs.com/cpuimage/p/90002…

华为IP-san实验搭建

文章目录 RedHat or CentOS系统1、获得多路径软件2、配置主机iscsi名3、配置存储映射4、主机访问存储的LUN5、安装多路径解决重复磁盘问题6、使用多路径扫盘 windows系统1、为win虚拟机提供多路径包文件2、创建存储与主机的连接3、主机使用磁盘 RedHat or CentOS系统 1、获得多…

为什么 kubernetes 环境要求开启 bridge-nf-call-iptables ?

文章目录 背景基于网桥的容器网络Service 同节点通信问题开启 bridge-nf-call-iptables我的环境netshoot 工具 参考 背景 Kubernetes 环境中&#xff0c;很多时候都要求节点内核参数开启 bridge-nf-call-iptables: sysctl -w net.bridge.bridge-nf-call-iptables1 参考官方文…

SQL语句的一些高级用法1

这里写目录标题 SQL语句的一些高级用法11.修改表名和表结构1&#xff0e;修改表名 2.扩展表结构&#xff08;增加字段&#xff09;3.修改字段&#xff08;列&#xff09;名&#xff0c;添加唯一键4&#xff0e;删除字段 案例扩展数据表高级操作1.克隆表&#xff0c;将数据表的数…

【Spring Boot学习】Spring Boot的创建和使用

前言&#xff1a; &#x1f49e;&#x1f49e;今天我们开始学习Spring Boot&#xff0c;这里我们会学习到怎么去创建和使用Spring Boot&#xff0c;在这里我们会了解到什么是最为核心的框架之一。 &#x1f49e;&#x1f49e;前路漫漫&#xff0c;希望大家坚持下去&#xff0c;…

大模型 Transformer介绍-Part1

众所周知&#xff0c;transformer 架构是自然语言处理 (NLP) 领域的一项突破。它克服了 seq-to-seq 模型&#xff08;如 RNN 等&#xff09;无法捕获文本中的长期依赖性的局限性。事实证明&#xff0c;transformer 架构是 BERT、GPT 和 T5 及其变体等革命性架构的基石。正如许多…

SpringBoot仿GPT数据流传输

目录 Java数据流传输响应前提Springboot文字流响应Web端接收流数据并显示 SpingBoot集成ChatGPT使用流响应结果 Java数据流传输响应 前提 在折腾ChatGpt集成在SpringBoot项目时&#xff0c;发现了ChatGpt api返回数据时有两种返回方式&#xff0c;一种是使用流传输&#xff0…