2024-06-24力扣每日一题

链接:

503. 下一个更大元素 II

题意

循环数组,找出每个元素的往后最近且大于它的元素

今天没试暴力啊,大概率是过不了的

思路就是先找到最大的数,最大数的结果肯定是-1,然后倒着遍历数组,用一个栈来从大到小的存放数字,就可以很方便的得到离自身最近的比自己大的数字,同时由于是倒着遍历,所以栈内数字一定在当前遍历的数字之后

核心思路是,从后往前遍历时 ,后遍历到的数字(位置靠前)的 数字是可以完全替换掉先遍历到的数字(位置靠后)

实际代码:

c++ 复制代码
#include<bits/stdc++.h>
using namespace std;
vector<int> nextGreaterElements(vector<int>& nums)
{
    int maxIndex=-1;
    int lg=nums.size();
    stack<int>tMax;
    vector<int>ans(lg,0);
    
    for(int i=0;i<lg;i++)
    {
        if(maxIndex==-1 || nums[i]>nums[maxIndex])
        {
            maxIndex=i;
        }
    }
    ans[maxIndex]=-1;tMax.push(nums[maxIndex]);
    
    for(int i=1;i<lg;i++)
    {
        int mao=(maxIndex-i+lg)%lg;
        
        while(tMax.size() && tMax.top()<=nums[mao])
        {
            tMax.pop();
        }
        
        if(tMax.size())
        {
            ans[mao]=tMax.top();
        }
        else ans[mao]=-1;
        
        tMax.push(nums[mao]);
    }
    
    return ans;
}
int main()
{
    vector<int> nums;
    int temp;
    
    while(cin>>temp)
    {
        nums.push_back(temp);
    }
    
    vector<int>ans=nextGreaterElements(nums);
    int lg=ans.size();
    //cout<<"lg:"<<lg<<endl;
    for(int i=0;i<lg;i++)
    {
        cout<<"i:"<<ans[i]<<endl;
    }
    return 0;
}

限制:

  • 1 <= nums.length <= 104
  • -109 <= nums[i] <= 109
相关推荐
sheeta19982 小时前
LeetCode 每日一题笔记 日期:2025.03.23 题目:1594.矩阵的最大非负积
笔记·leetcode·矩阵
灰色小旋风2 小时前
力扣22 括号生成(C++)
开发语言·数据结构·c++·算法·leetcode
圣保罗的大教堂3 小时前
leetcode 1594. 矩阵的最大非负积 中等
leetcode
重生之我是Java开发战士3 小时前
【广度优先搜索】队列:N叉树的层序遍历,二叉树的锯齿形层序遍历,二叉树的最大宽度,在每个树行中找最大值
数据结构·算法·leetcode·广度优先
灰色小旋风4 小时前
力扣20有效的括号(C++)
c++·算法·leetcode·职场和发展
逆境不可逃4 小时前
LeetCode 热题 100 之 160. 相交链表 206. 反转链表 234. 回文链表 141. 环形链表 142. 环形链表 II
算法·leetcode·链表
灰色小旋风4 小时前
力扣19删除链表的倒数第N个结点(C++)
c++·算法·leetcode·链表
keep intensify5 小时前
最小路径和
算法·leetcode·职场和发展
多打代码6 小时前
2026.03.23 最长递增子序列 & 最长连续递增序列 & 最长公共子序列
算法·leetcode·职场和发展
Q741_1477 小时前
力扣高频面试题详解 数组 链表 力扣 56.合并区间 力扣 160.相交链表 C++ 每日练习
c++·算法·leetcode·链表·数组·哈希