1、重新学习了栈的操作,isEmpty()、peek()以及pop()、push()操作
但是值得注意的点是push()必须要有输入
2、单调栈用在这里非常巧妙,通过暴力搜索的方法无法通过最后一个用例
并且通过使用单调栈可以使得时间复杂度从O(
)降到了O(
)
3、Deque
LinkedList 实现了 Deque 接口,可作为队列使用。
LinkedList
单调栈算法:
- class Solution {
- public int[] dailyTemperatures(int[] temperatures) {
- int[] answer = new int[temperatures.length];
- Deque
stack = new LinkedList<>(); - for(int i=0;i
- while( !stack.isEmpty() && temperatures[stack.peek()] < temperatures[i] ) {
- answer[stack.peek()] = i - stack.peek();
- stack.pop();
- }
- stack.push(i);
- }
- return answer;
- }
- }
-
暴力算法:
- class Solution {
- public int[] dailyTemperatures(int[] temperatures) {
- int[] answer = new int[temperatures.length];
- for(int i=0;i
- for(int j=i+1;j
- if( temperatures[j] > temperatures[i] ) {
- answer[i] = j-i;
- break;
- }
- // answer[i] = 0;
- }
- }
- return answer;
-
- }
- }
-
相关阅读:
费时3个月,靠着这篇软件测试进阶笔记,成功拿下了阿里、腾讯等10家offer
算法补天系列之——前缀树+贪心算法
灰度级形态学 - 灰度开运算和灰度闭运算
Rust权威指南之错误处理
笔记二十二、使用路由state进行传递参数
基于若依的ruoyi-nbcio流程管理系统仿钉钉流程json转bpmn的flowable的xml格式(排它条件网关)
【Java】抽象类
业务工人业务实体元模型-软件方法(下)第9章分析类图案例篇Part09
UML类图画法全程解析
4-6 最小生成树Prim,Kruskal(贪心)
-
原文地址:https://blog.csdn.net/weixin_43582743/article/details/133814688