力扣hot100:每日温度

题目

输入: temperatures = [73,74,75,71,69,72,76,73]

输出: [1,1,4,2,1,1,0,0]

说明:第一个温度为73,比73高的最近的是74,说明是一天,返回为1;

第二个温度为74,比74高的最近的是75,说明是一天,返回1;

第三个温度为75,比75高的最近的是76,说明是4天,返回4;以此类推;

解题思路

  • 最简单就是使用双层循环,两个指针,一个外层指针,一个内层指针,一个计数变量count,内存循环遍历,当后一个值比前一个值大的时候,count++,如果找到比前一个值大的温度,那就直接终端内存循环,修改数组i的值为count;
  • 比较简化的方式就可以考虑入栈出栈的方式,我们可以将对应的开始的数值的索引存储在栈中,然后取判断新的数据的值是不是比当前栈顶对应的值大,如果大,那就获取栈顶的索引值,减去当前的索引值,将其存储下来。
复制代码
var` `dailyTemperatures` `=` `function(arr)` `{`
    `let result =` `new` `Array(arr.length).fill(0)`
    `let stack =` `[]`
    `for(let i =` `0;i < arr.length;i++){`
        `while(stack.length >0` `&& arr[i]` `> arr[stack[stack.length-1]]){`
            `const index = stack.pop()`
`            result[index]` `= i - index`
        `}`
`        stack.push(i)`
    `}`
    `return result`
`};`
`const temperatures =` `[73,74,75,71,69,72,76,73]`
`console.log(dailyTemperatures(temperatures))`
`
相关推荐
rabbit_pro17 分钟前
SpringBoot3集成Langchain4j使用Ollama
java·开发语言
计算机安禾28 分钟前
【c++面向对象编程】第26篇:对象的内存模型:成员变量与成员函数的存储分离
开发语言·c++·算法
郝学胜-神的一滴32 分钟前
Qt 高级开发 005: Qt Creator与Visual Studio 项目双向转换
开发语言·c++·ide·qt·程序人生·visual studio
解决问题no解决代码问题39 分钟前
JAVA GC
java·开发语言·jvm
前端若水1 小时前
在 Vue 2 与 Vue 3 中使用 markdown-it-vue 渲染 Markdown 和数学公式
前端·javascript·vue.js
之歆1 小时前
DAY_10 JavaScript 深度解析:原型链 · 引用类型 · 内置对象 · 数组方法全攻略(下)
开发语言·前端·javascript·ecmascript
risc1234561 小时前
python 的字符串前缀
开发语言·python
小程故事多_801 小时前
Agent Loop 核心突破,上下文压缩四大流派,重新定义窗口资源利用率
java·开发语言·人工智能
如竟没有火炬1 小时前
字符串相乘——int数组转字符串
开发语言·数据结构·python·算法·leetcode·深度优先
吃好睡好便好1 小时前
在Matlab中绘制三维等高线图
开发语言·python·学习·算法·matlab·信息可视化