代码随想录算法训练营day59

news2024/11/27 10:32:29

文章目录

  • Day59
    • 下一个更大元素II
      • 题目
      • 思路
      • 代码
    • 接雨水
      • 题目
      • 思路
      • 代码

Day59

下一个更大元素II

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

题目

给定一个循环数组(最后一个元素的下一个元素是数组的第一个元素),输出每个元素的下一个更大元素。数字 x 的下一个更大的元素是按数组遍历顺序,这个数字之后的第一个比它更大的数,这意味着你应该循环地搜索它的下一个更大的数。如果不存在,则输出 -1。

示例 1:

  • 输入: [1,2,1]
  • 输出: [2,-1,2]
  • 解释: 第一个 1 的下一个更大的数是 2;数字 2 找不到下一个更大的数;第二个 1 的下一个最大的数需要循环搜索,结果也是 2。

提示:

  • 1 <= nums.length <= 10^4
  • -10^9 <= nums[i] <= 10^9

思路

本题要循环数组

查找元素右边最大值,使用单调递增栈(从栈口到栈底)

代码

class Solution {
    public int[] nextGreaterElements(int[] nums) {
        int len = nums.length;
        int res[] = new int[len];
        Arrays.fill(res, -1);
        LinkedList<Integer> stack = new LinkedList<>();
        stack.push(0);
        for(int i = 1; i < len * 2; i++){
            if(nums[stack.peek() % len] > nums[i % len]) stack.push(i);
            else if(nums[stack.peek() % len] == nums[i % len]) stack.push(i);
            else {
                while(!stack.isEmpty() && nums[stack.peek() % len] < nums[i % len]){
                    res[stack.peek() % len] = nums[i % len];
                    stack.pop();
                }
                stack.push(i);
            }
        }
        return res;
    }
}

接雨水

42. 接雨水 - 力扣(LeetCode)

题目

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。

示例 1:

  • 输入:height = [0,1,0,2,1,0,1,3,2,1,2,1]
  • 输出:6
  • 解释:上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示雨水)。

示例 2:

  • 输入:height = [4,2,0,3,2,5]
  • 输出:9

思路

只写了单调栈,其他方法(双指针,动态规划)看

代码随想录 (programmercarl.com)

准备工作

那么本题使用单调栈有如下几个问题:

  • 首先单调栈是按照行方向来计算雨水
  • 使用单调栈内元素的顺序

从栈头(元素从栈头弹出)到栈底的顺序应该是从小到大的顺序。

因为一旦发现添加的柱子高度大于栈头元素了,此时就出现凹槽了,栈头元素就是凹槽底部的柱子,栈头第二个元素就是凹槽左边的柱子,而添加的元素就是凹槽右边的柱子。

  • 遇到相同高度的柱子怎么办

遇到相同的元素,更新栈内下标,就是将栈里元素(旧下标)弹出,将新元素(新下标)加入栈中。

因为我们要求宽度的时候 如果遇到相同高度的柱子,需要使用最右边的柱子来计算宽度

  • 栈里要保存什么数值

使用单调栈,也是通过 长 * 宽 来计算雨水面积的。

长就是通过柱子的高度来计算,宽是通过柱子之间的下标来计算,

那么栈里有没有必要存一个pair<int, int>类型的元素,保存柱子的高度和下标呢。

其实不用,栈里就存放下标就行,想要知道对应的高度,通过height[stack.top()] 就知道弹出的下标对应的高度了。

单调栈处理逻辑

以下逻辑主要就是三种情况

  • 情况一:当前遍历的元素(柱子)高度小于栈顶元素的高度 height[i] < height[st.top()]
    • 如果当前遍历的元素(柱子)高度小于栈顶元素的高度,就把这个元素加入栈中,因为栈里本来就要保持从小到大的顺序(从栈头到栈底)。
if(height[i] < height[stack.peek()]) stack.push(i)
  • 情况二:当前遍历的元素(柱子)高度等于栈顶元素的高度 height[i] == height[st.top()]
    • 如果当前遍历的元素(柱子)高度等于栈顶元素的高度,要跟更新栈顶元素,因为遇到相相同高度的柱子,需要使用最右边的柱子来计算宽度。
if(height[i] == height[stack.peek()]){
	stack.pop();
	stack.push(i);
}
  • 情况三:当前遍历的元素(柱子)高度大于栈顶元素的高度 height[i] > height[st.top()]
    • 如果当前遍历的元素(柱子)高度大于栈顶元素的高度,此时就出现凹槽了

那么雨水高度是 min(凹槽左边高度, 凹槽右边高度) - 凹槽底部高度,代码为:int h = min(height[st.top()], height[i]) - height[mid];

雨水的宽度是 凹槽右边的下标 - 凹槽左边的下标 - 1(因为只求中间宽度),代码为:int w = i - st.top() - 1 ;

当前凹槽雨水的体积就是:h * w

while(!stack.isEmpty() && height[i] > height[stack.peek()]){
	int mid = stack.peek();
	stack.pop();
	if(!stack.isEmpty()){
		int h = Math.min(height[stack.peek()], height[i]) - height[mid];
		int w = i - stack.peek() - 1; // 注意减一,只求中间宽度
		sum += w * h;
	}
}
stack.push(i);

代码

class Solution {
    public int trap(int[] height) {
        if (height.length <= 2) return 0;
        int sum = 0;
        LinkedList<Integer> stack = new LinkedList<>();
        stack.push(0);
        for(int i = 1; i < height.length; i++){
            if(height[i] < height[stack.peek()]){
                stack.push(i);
            }else if(height[i] == height[stack.peek()]){
                stack.pop();
                stack.push(i);
            }else {
                while(!stack.isEmpty() && height[i] > height[stack.peek()]){
                    int mid = stack.peek();
                    stack.pop();
                    if(!stack.isEmpty()){
                        int h = Math.min(height[stack.peek()], height[i]) - height[mid];
                        int w = i - stack.peek() - 1; // 注意减一,只求中间宽度
                        sum += w * h;
                    }
                }
                stack.push(i);
            }
        }
        return sum;
    }
}

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

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

相关文章

无涯教程-Perl - exit函数

描述 该函数判断EXPR,退出Perl解释器,并返回该值作为退出值。始终在退出之前运行脚本(和导入的程序包)中定义的所有END {}块。如果省略EXPR,则解释器以0值退出。不应用于退出子例程&#xff1b;否则,解释器将退出子例程。使用eval而死或使用return。 语法 以下是此函数的简单…

ffmpeg下载安装教程

ffmpeg官网下载地址https://ffmpeg.org/download.html 这里以windows为例,鼠标悬浮到windows图标上,再点击 Windows builds from gyan.dev 或者直接打开 https://www.gyan.dev/ffmpeg/builds/ 下载根据个人需要下载对应版本 解压下载的文件,并复制bin所在目录 新打开一个命令…

有谁可以介绍一些团队任务分配管理软件?

首先我们谈一谈做好团队任务分配管理能够有哪些帮助—— 最明显的就是能够大大提高工作效率。通过合理的任务分配&#xff0c;可以确保每个团队成员都能够专注于自己的职责和任务&#xff0c;避免资源浪费和重复劳动。团队成员清楚自己的任务&#xff0c;能够更加高效地完成工…

23款奔驰S450 4MATIC加装车载冰箱系统,快乐就是这么朴实无华呀

凉爽餐饮随时触手可及。容积10升的可拆卸冷藏箱与后排扶手和谐融合。如此一来&#xff0c;即使在炎炎夏日&#xff0c;也可享受沁凉的冷饮。

裂墙推荐服务设计:品牌设计的大方向,全流程设计

裂墙推荐服务设计&#xff1a;品牌设计的大方向 通过简单LOGO和口号形象打造好品牌 是太幼稚想法&#xff0c;图样图森破 品牌设计已经向全流程体验方向走 甚至供应链体系也必须加入其中 趣讲大白话&#xff1a;品牌建设太卷了 【趣讲信息科技250期】 ************************…

MySQL及SQL语句(3)

MySQL及SQL语句(3) 文章目录 MySQL及SQL语句(3)一、多表查询1.1 准备sql1.2 笛卡尔积1.3 多表查询的分类&#xff1a;内连接查询外连接查询子查询多表查询练习 二、事务2.1 事务的基本介绍概念操作实例事务提交的两种方式 2.2 事务的四大特征原子性持久性隔离性一致性 2.3 事务…

STL容器之vector

1、构造初始化 #include <iostream> #include <vector> using namespace std;void PrintVector(vector<int>& v) {for (vector<int>::iterator it v.begin(); it ! v.end(); it){cout << *it << " ";}cout << endl;…

Linux Shell 编程入门

从程序员的角度来看&#xff0c; Shell本身是一种用C语言编写的程序&#xff0c;从用户的角度来看&#xff0c;Shell是用户与Linux操作系统沟通的桥梁。用户既可以输入命令执行&#xff0c;又可以利用 Shell脚本编程&#xff0c;完成更加复杂的操作。在Linux GUI日益完善的今天…

MyBatics-学习笔记

文章目录 1.概念介绍2.Mybatis快速入门1.创建用户表2.创建模块导入坐标3.编写配置文件4.编写sql映射文件5.编码 3.Mapper代理开发4.MyBatis核心配置文件5.商品增删改查案例&#xff08;重点&#xff09;6.参数传递6.2 多个参数 1.概念介绍 概念 MyBatis 是一款支持普通 SQL 查询…

【构建卷积神经网络】

构建卷积神经网络 卷积网络中的输入和层与传统神经网络有些区别&#xff0c;需重新设计&#xff0c;训练模块基本一致 全连接层&#xff1a;batch784&#xff0c;各个像素点之间都是没有联系的。 卷积层&#xff1a;batch12828&#xff0c;各个像素点之间是有联系的。 impor…

LaTex使用技巧21:设置中文环境、字体、行间距和页边距

我在Overleaf上编写我的中文LaTex&#xff0c;设置了中文环境&#xff0c;字体、行间距以及页间距&#xff0c;记录一下方便以后查询。 使用中文环境命令为&#xff1a; \usepackage{xeCJK}可以使用Overleaf上支持的中文字体Fonts for CJK Chinese&#xff0c;设置字体的命令…

探究使用HTTP爬虫ip后无法访问网站的原因与解决方案

在今天的文章中&#xff0c;我们要一起来解决一个常见问题&#xff1a;使用HTTP爬虫ip后无法访问网站的原因是什么&#xff0c;以及如何解决这个问题。我们将提供一些实际的例子和操作经验&#xff0c;帮助大家解决HTTP爬虫ip无法访问网站的困扰。 1、代理服务器不可用 使用HT…

Debian 12.1 正式发布

导读Debian 12.1 现已发布&#xff0c;这是对稳定发行版 Debian 12&#xff08;代号 Bookworm &#xff09;的首次更新。本次发布主要增加了安全问题的修正&#xff0c;并对严重问题进行了一些调整。 一些更新内容包括&#xff1a; 妥善处理系统用户的创建&#xff1b;修复 eq…

ChatGLM-RLHF(五)-PPO(Proximal Policy Optimization)原理实现代码逐行注释

一&#xff0c;前言 从open AI 的论文可以看到&#xff0c;大语言模型的优化&#xff0c;分下面三个步骤&#xff0c;SFT&#xff0c;RM&#xff0c;PPO&#xff0c;我们跟随大神的步伐&#xff0c;来学习一下这三个步骤和代码实现&#xff0c;本章介绍PPO代码实现。 上章我们…

Java编程实践:实现Java接口的方法也建议加上@Override注解

说明 作为一个Java编程实践&#xff0c;实现接口的方法也强烈建议加上Override注解。这样做的好处&#xff1a; 阅读代码的时候&#xff0c;一眼就能看出来是新增的函数&#xff0c;还是实现接口的函数。加上Override注解&#xff0c;如果拼写错误&#xff0c;编译器马上就能…

电视盒子哪款好?内行整理超值网络电视盒子推荐

从事电视盒子这行已经五年了&#xff0c;很多朋友在挑选电视盒子时会咨询我的意见&#xff0c;我耗费半个月时间整理了超值网络电视盒子推荐&#xff0c;盘点目前最值得入手的五款电视盒子机型&#xff0c;想买电视盒子不知道电视盒子哪款好可以从下面五款中挑选&#xff1a; 榜…

VIM 编辑器: Bram Moolenaar

VIM 用了很长时间&#xff0c; 个人的 VIM 配置文件差不多10年没有更新了。以前写程序的时候&#xff0c; 编辑都用这个。 linux kernel&#xff0c; boost规模的代码都不在话下。现在虽然代码写的少了&#xff0c;依然是我打开文件的首选。 现在用手机了&#xff0c;配个蓝牙键…

idea中如何处理飘红提示

idea中如何处理飘红提示 在写sql时&#xff0c;总是会提示各种错误 查找资料&#xff0c;大部分都是说关提示&#xff0c;这里把错误提示选择为None即可 关掉以后&#xff0c;也确实不显示任何提示了&#xff0c;但总有一种掩耳盗铃的感觉 这个sms表明明存在&#xff0c;但是还…

android studio安卓真机调试

把usb 手机开启到usb调试模式,然后用usb线连接手机 安装adb 如果下载速度很慢,请使用vpn 终端需要先安装brew /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"使用brew安装adb brew install android-platfor…

面试遇到登录功能测试用例设计,你回答对了吗

给你一个登录功能&#xff0c;如何设计测试用例 哪怕是最常用最小的一个登录功能&#xff0c;其实涉及到的测试用例也是非常多的&#xff0c;这个题目通常会通过面试来考察求职者的综合能力&#xff0c;尤其是测试用例的设计思维&#xff0c;因为你即使你背了各种测试用例设计…