牛客2024【牛客赛文X】春招冲刺ONT61 每日温度【hard 单调栈 Java、Go、PHP】

题目

在这里插入图片描述题目链接:
https://www.nowcoder.com/practice/1f54e163e6944cc7b8759cc09e9c78d8

思路

	单调栈最直接的应用就是获取数组中每个位置i,i的左边第一个比i大或者小的位置/数以及,i的右边第一个比i大或者小的位置/数不懂的同学看这里https://blog.csdn.net/Borslav/article/details/125469491

参考答案Java

import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** 每日温度* @param dailyTemperatures int整型一维数组* @return int整型一维数组*/public int[] temperatures (int[] dailyTemperatures) {//单调栈,递减栈// 也就是先求每个元素i左边,右边离他最近的第一个大于i的数,没有大于i的用-1表示int n = dailyTemperatures.length;int[][] bigarr = new int[n][2];//单调递减栈Stack<List<Integer>> stack = new Stack<>();for (int i = 0; i < n ; i++) {while (!stack.isEmpty() &&dailyTemperatures[stack.peek().get(0)] < dailyTemperatures[i]) {List<Integer> pops = stack.pop();int leftBigger = stack.isEmpty() ? -1 : stack.peek().get(stack.peek().size() - 1);for (Integer pop : pops) {bigarr[pop][0] = leftBigger; //pop左边边第一个比pop大的位置bigarr[pop][1] = i; //pop右边第一个比pop大的位置}}if (!stack.isEmpty() &&dailyTemperatures[stack.peek().get(0)] == dailyTemperatures[i]) {stack.peek().add(i);} else {List<Integer> ll = new ArrayList<>();ll.add(i);stack.push(ll);}}while (!stack.isEmpty()) {List<Integer> pops = stack.pop();int leftBigger = stack.isEmpty() ? -1 : stack.peek().get(stack.peek().size() - 1);for (Integer pop : pops) {bigarr[pop][0] = leftBigger;bigarr[pop][1] = -1;}}//前面的代码是通用的单调栈的模板,// 答案中我们只需要用到bigarr中每个元素的1下标,即右边第一个比自己大的位置int[] ans = new int[n];for (int i = 0; i < n ; i++) {if (bigarr[i][1] == -1) {ans[i] = 0;} else {ans[i] = bigarr[i][1] - i;}}return ans;}
}

参考答案Go

package main/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** 每日温度* @param dailyTemperatures int整型一维数组* @return int整型一维数组*/
func temperatures(dailyTemperatures []int) []int {//单调栈,递减栈// 也就是先求每个元素i左边,右边离他最近的第一个大于i的数,没有大于i的用-1表示n := len(dailyTemperatures)bigarr := make([][]int, n)//单调递减栈stack := [][]int{} //GO中栈用切片表示即可for i := 0; i < n; i++ {stlen := len(stack)for len(stack) > 0 && dailyTemperatures[stack[stlen-1][len(stack[stlen-1])-1]] < dailyTemperatures[i] {pops := stack[stlen-1]stack = stack[:stlen-1]leftbig := 0if len(stack) == 0 {leftbig = -1} else {stlen = len(stack)leftbig = stack[stlen-1][len(stack[stlen-1])-1]}for _, v := range pops {bigarr[v] = make([]int, 2)bigarr[v][0] = leftbig //v左边第一个比v大的位置bigarr[v][1] = i       //v右边第一个比v大的位置}}stlen = len(stack)if len(stack) > 0 && dailyTemperatures[stack[stlen-1][len(stack[stlen-1])-1]] == dailyTemperatures[i] {stack[stlen-1] = append(stack[stlen-1], i)} else {list := []int{}list = append(list, i)stack = append(stack, list)}}for len(stack) > 0 {stlen := len(stack)pops := stack[stlen-1]stack = stack[:stlen-1]leftbig := 0if len(stack) == 0 {leftbig = -1} else {stlen = len(stack)leftbig = stack[stlen-1][len(stack[stlen-1])-1]}for _, v := range pops {bigarr[v] = make([]int, 2)bigarr[v][0] = leftbigbigarr[v][1] = -1}}//前面的代码是通用的单调栈的模板,// 答案中我们只需要用到bigarr中每个元素的1下标,即右边第一个比自己大的位置ans := make([]int, n)for i := 0; i < n; i++ {if bigarr[i][1] == -1 {ans[i] = 0} else {ans[i] = bigarr[i][1] - i}}return ans
}

参考答案PHP

在这里插入代码片

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

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

相关文章

String类中常见面试题

1.string类属于基本类型吗&#xff1f; string类不是基本类型&#xff1b;它属于引用数据类型 2.操作字符串的类有哪些?有什么区别&#xff1f; 有三种&#xff1a;string,stringBuilder,stringBuffer 区别&#xff1a; String:不可变类&#xff0c;字符串一旦被创建就不能…

Unity打包出来的apk安装时提示应用程式与手机不兼容,无法安装应用程式

1、遇到的问题 * 2、解决办法 这是因为你在Unity中导出来的apk手机安装包是32位的&#xff0c;才导致上述问题发生&#xff0c;要解决这个办法&#xff0c;需要在Unity中导出64位的手机安装包。 32位跟64位的区别&#xff0c;以及如何区分打出来的手机安装包是否是32位或者是…

C++11 新特性:tuple 元组

std::tuple是 C11 中引入的一个非常强大的类型&#xff0c;它允许将多个类型不同的值&#xff0c;组合成单一对象。 std::tuple非常适合用于那些需要返回多个值的场景&#xff0c;而且它的灵活性和通用性使得其成为现代 C 编程中不可或缺的一部分。下面&#xff0c;我们将探讨…

腐蚀Rust 服务端搭建架设个人社区服务器Windows教程

腐蚀Rust 服务端搭建架设个人社区服务器Windows教程 大家好我是艾西&#xff0c;一个做服务器租用的网络架构师也是游戏热爱者。最近在steam发现rust腐蚀自建的服务器以及玩家还是非常多的&#xff0c;那么作为服务器供应商对这商机肯定是不会放过的哈哈哈&#xff01; 艾西这…

Day:004(4) | Python爬虫:高效数据抓取的编程技术(数据解析)

XPath工具 浏览器-元素-CtrlF 浏览器-控制台- $x(表达式) Xpath helper (安装包需要科学上网) 问题 使用离线安装包 出现 程序包无效 解决方案 使用修改安装包的后缀名为 rar&#xff0c;解压文件到一个文件夹&#xff0c;再用 加载文件夹的方式安装即可 安装 python若使用…

2024年认证杯SPSSPRO杯数学建模D题(第一阶段)AI绘画带来的挑战全过程文档及程序

2024年认证杯SPSSPRO杯数学建模 D题 AI绘画带来的挑战 原题再现&#xff1a; 2023 年开年&#xff0c;ChatGPT 作为一款聊天型 AI 工具&#xff0c;成为了超越疫情的热门词条&#xff1b;而在 AI 的另一个分支——绘图领域&#xff0c;一款名为 Midjourney&#xff08;MJ&…

【Apache2】彻底删除 Apache2 服务器

要彻底删除 Apache2 服务器&#xff0c;需要卸载 Apache2 软件包并删除其配置文件和数据文件。在 Ubuntu 上&#xff0c;可以按照以下步骤来完成&#xff1a; 停止 Apache2 服务&#xff1a; sudo systemctl stop apache2卸载 Apache2 软件包&#xff1a; sudo apt-get purge a…

JavaWeb--前端--01HTML和CSS

文章目录 1 前端开发介绍2 开发工具3 文档查阅4 VSCode的插件 1 前端开发介绍 Web标准也称为网页标准&#xff0c;由一系列的标准组成&#xff0c;大部分由W3C&#xff08; World Wide Web Consortium&#xff0c;万维网联盟&#xff09;负责制定。由三个组成部分&#xff1a;…

2024年认证杯数学建模挑战赛C题全解析

2024年认证杯C题的已经完成啦&#xff0c;包括参考论文&#xff0c;模型代码&#xff0c;分享给大家&#xff5e; 问题分析 对于这些问题&#xff0c;我们首先需要确定影响日光辐射降低效应的关键参数&#xff0c;例如海盐气溶胶的浓度、粒子大小、分布以及喷洒高度和范围。同…

使用Spring Cloud构建微服务时的一些经验

在使用Spring Cloud构建微服务的过程中&#xff0c;积累了大量的实践经验&#xff0c;也遇到了一些挑战。以下是对使用Spring Cloud进行微服务开发的经验和观察&#xff1a; 1. 服务治理与发现 Spring Cloud Eureka或Consul提供了服务治理和发现的功能&#xff0c;使得微服务…

再写-全景拼接

全景拼接 1. 将读取进行灰度转化&#xff0c;并且输出图像&#xff0c;关键点和计算描述 import cv2 import numpy as np# 将读取进行灰度转化&#xff0c;并且输出图像&#xff0c;关键点和计算描述 image_left cv2.imread("C:\\Users\\HONOR\\Desktop\\image\\pinjie…

机器人坐标系转换之从世界坐标系到局部坐标系

三角函数实现 下面是代码c和python实现&#xff1a; #include <iostream> #include <cmath>struct Point {double x;double y; };class RobotCoordinateTransform { private:Point origin; // 局部坐标系的原点在世界坐标系中的坐标public:RobotCoordinateTransfo…

高压电容:能源革命中的重要角色

高压电容在能源革命中扮演着重要的角色&#xff0c;主要体现在以下几个方面&#xff1a; 能源存储和管理&#xff1a;随着可再生能源的不断普及和发展&#xff0c;如太阳能和风能等&#xff0c;能源的不稳定性和间歇性成为了一个挑战。高压电容可以作为一种高效的能源存储和管理…

【深度学习】图像风格混合——StyleGAN2原理解析

1、前言 上一篇文章&#xff0c;我们详细讲解了StyleGAN的原理。这篇文章&#xff0c;我们就来讲解一下StyleGAN2&#xff0c;也就是StyleGAN的改进版。 原论文&#xff1a;Analyzing and Improving the Image Quality of StyleGAN 参考代码&#xff1a;①Pytorch版本&#…

【Godot4.2】CanvasItem绘图函数全解析 - 7.自定义节点TextBoard

概述 之前发布的几篇文章几乎阐述了CanvasItem绘图函数最基础的内容。 本篇结合draw_style_box()和TextParagraph类&#xff0c;自定义了一个可以自适应宽高显示多行文本&#xff0c;且带有一个样式盒作为背景的文字板节点TextBoard。 系列目录 0.概述1.绘制简单图形2.设定绘…

SPP论文笔记

这篇论文讨论了在深度卷积网络中引入空间金字塔池化&#xff08;SPP&#xff09;层的方法&#xff0c;以解决传统深度卷积网络需要固定图像尺寸的限制。以下是论文各部分的总结&#xff1a; 1. 引言 论文指出现有的深度卷积神经网络&#xff08;CNN&#xff09;需要固定大小的…

全景剖析SSD SLC Cache缓存设计原理-2

四、SLC缓存对SSD的寿命是否有优化&#xff1f; 当使用QLC或TLC NAND闪存并将其切换到SLC模式进行写入时&#xff0c;会对闪存的寿命产生以下影响&#xff1a; 短期寿命提升&#xff1a; SLC模式下&#xff0c;每个存储单元仅存储一个比特数据&#xff0c;相对于QLC或TLC来说…

前端vue: 使用ElementUI适配国际化

i18n介绍 i18n&#xff08;其来源是英文单词 internationalization的首末字符i和n&#xff0c;18为中间的字符数&#xff09;是“国际化”的简称。 前端国际化步骤 1、安装i18n插件 安装插件时候&#xff0c;注意必须指定版本号&#xff0c;不然安装会报错。 npm i vue-i1…

linux 部署安装mongodb教程

现在去官网下载mongodb的tar包,在本地创建文件夹 cd /home wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.2.17.tgz tar -zxvf mongodb-linux-x86_64-rhel70-4.2.17.tgz mv mongodb-linux-x86_64-rhel70-4.2.17 mongodb cd /home/mongodb mkdir log t…

GAN:对抗式生成网络之图片生成

对抗式生成网络(Adversarial Generative Network, AGN)这一术语在您提供的信息中并未直接出现。通常,在深度学习文献和实践中,与“对抗”和“生成”概念相结合的网络架构指的是生成式对抗网络(Generative Adversarial Networks, GANs)。GANs由Ian Goodfellow等人于2014年…