力扣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))`
`
相关推荐
小小测试开发13 小时前
安装 Python 3.10+
开发语言·人工智能·python
AAA大运重卡何师傅(专跑国道)15 小时前
【无标题】
开发语言·c#
sugar__salt15 小时前
从栈队列数据结构到JS原型面向对象全解
前端·javascript·数据结构
XBodhi.15 小时前
Visual Studio C++ 语法错误: 缺少“;”(在“return”的前面)
开发语言·c++·visual studio
MageGojo15 小时前
随机文案模块怎么做?从接口封装到前端展示的完整实现思路
javascript·前端开发·api接口·后端开发·随机文案
独特的螺狮粉15 小时前
篮球集训班器具管理系统 - 鸿蒙PC Electron框架完整技术实现指南
前端·javascript·华为·electron·前端框架·开源·鸿蒙
小妖66615 小时前
js 生成随机数技巧 Math.random().toString(36)
javascript·随机数
LSssT.16 小时前
【01】Python 机器学习
开发语言·python
AI_零食16 小时前
番茄钟鸿蒙PC Electron框架完成:状态机、定时器管理与专注力工具设计
前端·javascript·华为·electron·开源·鸿蒙·鸿蒙系统
提子拌饭13316 小时前
逛三园游戏——基于鸿蒙PC Electron框架实现
前端·javascript·游戏·华为·electron·鸿蒙