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}

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

go 复制代码
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中。

然后是从右到左的方法:

go 复制代码
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
}
相关推荐
智驱力人工智能8 分钟前
无人机河道漂浮物检测 从项目构建到价值闭环的系统工程 无人机河道垃圾识别 农村河道漂浮物智能清理方案 无人机辅助河道清洁预警
opencv·算法·安全·yolo·目标检测·无人机·边缘计算
德福危险16 分钟前
C语言数据类型与变量 系统总结笔记
c语言·笔记·算法
@淡 定17 分钟前
JVM调优参数配置详解
java·jvm·算法
CoovallyAIHub25 分钟前
从电影特效到体育科学,运动追踪只能靠“人眼”吗?
深度学习·算法·计算机视觉
风筝在晴天搁浅25 分钟前
hot100 48.旋转图像
算法
TechNomad42 分钟前
排序算法:希尔排序算法
数据结构·算法·排序算法
热爱生活的猴子42 分钟前
算法中DFS & BFS 核心学习笔记
算法·深度优先·宽度优先
im_AMBER43 分钟前
Leetcode 83 使数组平衡的最少移除数目中等相关标签 | 尽可能使字符串相等
数据结构·c++·笔记·学习·算法·leetcode
TechNomad1 小时前
排序算法:快速排序算法
算法·排序算法
xu_yule1 小时前
算法基础(图论)—拓扑排序
c++·算法·动态规划·图论·拓扑排序·aov网