返回顶部
首页 > 资讯 > 后端开发 > Python >Java算法真题详解运用单调栈
  • 209
分享到

Java算法真题详解运用单调栈

2024-04-02 19:04:59 209人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

目录1.下一个更大元素题目描述思路详解代码与结果2.每日温度题目描述思路详解代码与结果3.下一个更大元素II题目描述思路详解代码与结果1.下一个更大元素 题目描述 思路详解 这一题

1.下一个更大元素

题目描述

思路详解

这一题就选取比较暴力 的解法了。

我们先初始化一个与nums等长度的res数组用来存储结果,我们遍历取出nums中的值,到nums2中寻找,直到找到nums2[j] == nums[i] ,我们再从 nums2的 j 之后遍历找到比nums[i]大的数组返回,找不到就返回-1.

代码与结果

class Solution {
    public int[] nextGreaterElement(int[] nums1, int[] nums2) {
        int m = nums1.length, n = nums2.length;
        int[] res = new int[m];
        for (int i = 0; i < m; ++i) {
            int j = 0;
            while (j < n && nums2[j] != nums1[i]) {
                ++j;
            }
            int k = j + 1;
            while (k < n && nums2[k] < nums2[j]) {
                ++k;
            }
            res[i] = k < n ? nums2[k] : -1;
        }
        return res;
    }
}

2.每日温度

题目描述

思路详解

这一题也是使用比较暴力的方法。同上一题一样。

两重循环,显然这种方法时间复杂度较高。这里也提供一种时间复杂度较低的方法。

单调栈

我们维护的是一个差距数组也就是结果数组,首先创建一个栈,判断栈是否为空,若为空直接入栈,若不为空则比较栈顶元素与当前元素,如果当前元素大于当前元素就把差值放入到对应结果数组同时栈顶元素出栈,若当前元素小于结果数组则入栈。

这里给一个动画链接很好董,动画学单调栈。

代码与结果

class Solution {
    public int[] dailyTemperatures(int[] temperatures) {
        int[] answer = new int[temperatures.length];
        for(int i = 0 ; i < temperatures.length ; i++){
            int res = 0;
            for(int j = i+1 ; j < temperatures.length; j++){
                res++;
                if(temperatures[j] > temperatures[i]){
                    answer[i] = res;
                    break;
                } 
            }
        }
        return answer;
    }
}

3.下一个更大元素II

题目描述

思路详解

本题的思路呢单调栈,问题一暴力破解,这个题要使用单调栈了。

原理同第二题的方法一样,就在循环上注意一下就可以了。直接上代码,不董的可以看第二题的视频再来看这个哦。

代码与结果

class Solution {
    public int[] nextGreaterElements(int[] nums) {
        int n = nums.length;
        int[] ret = new int[n];
        Arrays.fill(ret, -1);
        Deque<Integer> stack = new LinkedList<Integer>();
        for (int i = 0; i < n * 2 - 1; i++) {//最多循环一次,只需要2*n-1就够用了
            while (!stack.isEmpty() && nums[stack.peek()] < nums[i % n]) {
                ret[stack.pop()] = nums[i % n];
            }
            stack.push(i % n);//利用取模来进行循环也是一种常用的方法
        }
        return ret;
    }
}

到此这篇关于Java算法真题详解运用单调栈 的文章就介绍到这了,更多相关Java单调栈 内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Java算法真题详解运用单调栈

本文链接: https://lsjlt.com/news/164862.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作