zoukankan      html  css  js  c++  java
  • 496. Next Greater Element I

    Question:

    You are given two arrays (without duplicates) nums1 and nums2 where nums1’s elements are subset of nums2. Find all the next greater numbers for nums1's elements in the corresponding places of nums2.

    The Next Greater Number of a number x in nums1 is the first greater number to its right in nums2. If it does not exist, output -1 for this number.

    Example 1:

    Input: nums1 = [4,1,2], nums2 = [1,3,4,2].
    Output: [-1,3,-1]
    Explanation:
        For number 4 in the first array, you cannot find the next greater number for it in the second array, so output -1.
        For number 1 in the first array, the next greater number for it in the second array is 3.
        For number 2 in the first array, there is no next greater number for it in the second array, so output -1.

    Example 2:

    Input: nums1 = [2,4], nums2 = [1,2,3,4].
    Output: [3,-1]
    Explanation:
        For number 2 in the first array, the next greater number for it in the second array is 3.
        For number 4 in the first array, there is no next greater number for it in the second array, so output -1.

    Note:

    1. All elements in nums1 and nums2 are unique.
    2. The length of both nums1 and nums2 would not exceed 1000.

    Solution:

    class Solution {
    public:
        vector<int> nextGreaterElement(vector<int>& findNums, vector<int>& nums) {
            vector<int> result;
            stack<int> s;
            map<int, int> m;
            for (int i = nums.size() - 1; i >= 0; i--) {
                while (!s.empty() && s.top() <= nums[i]) 
                    s.pop();
                m[nums[i]] = s.empty() ? -1 : s.top();
                s.push(nums[i]);
            }
            for (int i = 0; i < findNums.size(); i++)
                result.push_back(m[findNums[i]]);
            return result;
        }
    };

    题目直达:https://leetcode.com/problems/next-greater-element-i/#/description

    答案直达:http://www.liuchuo.net/archives/3197

  • 相关阅读:
    构造方法
    封装 private
    局部变量和成员变量区别
    IOC
    Linux端口占用查询命令
    Nginx小白入门实战
    SQL left join right join inner join之间的区别
    IDEA导入maven工程时,不会自动识别怎么办
    Spring中Controller层中的method显示为灰色并且提示method is never used的原因
    查看服务器公网IP
  • 原文地址:https://www.cnblogs.com/SapphireCastle/p/6759625.html
Copyright © 2011-2022 走看看