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

leetcode739 每日温度

题目

给定一个整数数组 temperatures ,表示每天的温度,返回一个数组 answer ,其中 answer[i] 是指对于第 i 天,下一个更高温度出现在几天后。如果气温在这之后都不会升高,请在该位置用 0 来代替。

示例

输入: temperatures = [73,74,75,71,69,72,76,73]
输出: [1,1,4,2,1,1,0,0]

解析

这道题的测试用例其实可以用这个:
在这里插入图片描述
temp := []int{1, 4, 3, 5, 5, 2, 3, 6}

这道题可以有两种方法,首先看从左到右的方法:

func dailyFromLeft(temperature []int) []int {n := len(temperature)// 两个额外数组,一个存结果ans,这个默认已经初始化为0了,后面更新哪个位置,就将对应的下标间隔更新进去ans := make([]int, n)// 另一个就是栈,栈中存的是下标stack := []int{}for i, value := range temperature {for len(stack) > 0 && value > temperature[stack[len(stack)-1]] {j := stack[len(stack)-1]     // 之前存在栈里的下标stack = stack[:len(stack)-1] // 弹出栈顶ans[j] = i - j}stack = append(stack, i)}return ans
}

这道题愣是去理解的话,还是有点费劲,建议根据上面的那个测试用例来进行debug,首先在从左到右的顺序遍历过程中,栈中存的下标用j来表示,就相当于遍历到i的时候(此时j小i大,那距离就是i-j),就相当于在第一次遍历到的某个位置的时候,此时还不知道后面谁比他大的,遍历到第一个比它大的时候才进行计算,添加到ans中。

然后是从右到左的方法:

func dailyTemperatures(temperatures []int) []int {n := len(temperature)// 两个额外数组,一个存结果ans,这个默认已经初始化为0了,后面更新哪个位置,就将对应的下标间隔更新进去ans := make([]int, n)// 另一个就是栈,栈中存的是下标stack := []int{}for i := n - 1; i >= 0; i-- {value := temperature[i]for len(stack) > 0 && value >= temperature[stack[len(stack)-1]] { // 从右到左遍历,当前的高度大于栈中的数据,就弹出栈中的小的数据stack = stack[:len(stack)-1]}if len(stack) > 0 {ans[i] = stack[len(stack)-1] - i // 将栈中存的比当前位置大的下标与当前位置下标相减}stack = append(stack, i) // stack中存的是下标}return ans
}
http://www.lryc.cn/news/362661.html

相关文章:

  • 【软件测试】自动化测试如何管理测试数据
  • Llama 3-V: 比GPT4-V小100倍的SOTA
  • Anaconda安装配置
  • 全面理解渗透测试
  • 「网络编程」基于 UDP 协议实现回显服务器
  • 云数融合与大数据技术在日常生活中的创新应用探索
  • ETCD 备份与还原
  • LeeCode 1787 DP
  • 如何有效屏蔽手机上的骚扰电话20240530
  • Linux CGroup资源限制(概念限制进程CPU使用)
  • Latex中标注通讯作者
  • PyQt5开发笔记:1.环境搭建与界面美化
  • 公派/自费访问学者申请出国访学的常见问题解答(下)
  • 完全指南:C语言学习资源汇总
  • Kubernetes——Ingress详解
  • 反射、类加载、静态代理,jdk动态代理,cglib代理
  • MySQL Hints:控制查询优化器的选择
  • 【TB作品】msp430g2553单片机,OLED,PCF8591,ADC,DAC
  • C#WPF数字大屏项目实战10--不良指标分页
  • 数字塔问题
  • 【介绍下Pwn,什么是Pwn?】
  • Python:b站多个视频爬取下载
  • Java常规题技术分享
  • Pytorch语义分割(1)-----加载数据
  • Java中加号的多种用途
  • React useCallback用法
  • Flutter 中的 ErrorWidget 小部件:全面指南
  • 【数据结构】穿梭在二叉树的时间隧道:顺序存储的实现
  • 【数据结构与算法 经典例题】链表的回文结构(图文详解)
  • 通过DirectML和ONNXRuntime运行Phi-3模型