【代码随想录】【算法训练营】【第53天】 [739]每日温度 [496]下一个更大元素I [503]下一个更大元素II

前言

思路及算法思维,指路 代码随想录

题目来自 LeetCode

day 48,周六,不能再坚持~

题目详情

[739] 每日温度

题目描述

739 每日温度

解题思路

前提:寻找任一个元素的右边比自己大的元素的位置

思路:通常是一维数组,要寻找任一个元素的右边或者左边第一个比自己大或者小的元素的位置,此时可以用单调栈,使用空间换时间

重点:单调栈的实现思维

代码实现

C语言
单调栈
c 复制代码
/**
 * Note: The returned array must be malloced, assume caller calls free().
 */
int* dailyTemperatures(int* temperatures, int temperaturesSize, int* returnSize) {
    int *ans = (int *)malloc(sizeof(int) * temperaturesSize);
    int stack[temperaturesSize];
    int top = 0;

    memset(ans, 0, sizeof(int) * temperaturesSize);
    memset(stack, 0, sizeof(stack));

    for (int i = 0; i < temperaturesSize; i++) {
        while (top > 0 && temperatures[i] > temperatures[stack[top - 1]]) {
            // 当前元素 大于 栈顶元素,找到栈顶元素的右侧第一个更高温度
            ans[stack[top - 1]] = i - stack[top - 1];
            top--;
        }
        stack[top] = i;
        top++;
    }
    *returnSize = temperaturesSize;
    return ans;
}

[496] 下一个更大元素I

题目描述

496 下一个更大元素I

解题思路

前提:寻找另一数组中相同元素的右侧第一个比其大的值

思路:对nums2使用单调栈,再利用哈希对nums1中元素赋值

重点:单调栈的实现思维

代码实现

C语言
单调栈
c 复制代码
/**
 * Note: The returned array must be malloced, assume caller calls free().
 */
#define NUM_MAX_SIZE 10001
int* nextGreaterElement(int* nums1, int nums1Size, int* nums2, int nums2Size, int* returnSize) {
    int *ans = (int *)malloc(sizeof(int) * nums1Size); 
    int map[NUM_MAX_SIZE];
    memset(map, -1, sizeof(map));
    for (int i = 0; i < nums1Size; i++) {
        ans[i] = -1;
        map[nums1[i]] = 0;
    }

    // 对nums2使用单调栈
    int stack[NUM_MAX_SIZE];
    memset(stack, -1, sizeof(stack));
    int top = 0;
    for (int i = 0; i < nums2Size; i++) {
        while (top > 0 && nums2[i] > nums2[stack[top - 1]]) {
            // 当前元素大于栈顶元素,找到栈顶元素右侧的第一个更大元素
            map[nums2[stack[top - 1]]] = nums2[i];
            top--;
        }
        stack[top] = i;
        top++;
    }

    // 赋值结果
    for (int i = 0; i < nums1Size; i++) {
        if (map[nums1[i]] > 0) {
            ans[i] = map[nums1[i]];
        } else {
            ans[i] = -1;
        }
    }

    *returnSize = nums1Size;
    return ans;
}

[503] 下一个更大元素II

题目描述

503 下一个更大元素II

解题思路

前提:寻找同一数组中相同元素的右侧第一个比其大的值,可循环查找

思路:循环两次对nums使用单调栈

重点:单调栈的实现思维

代码实现

C语言
单调栈
c 复制代码
/**
 * Note: The returned array must be malloced, assume caller calls free().
 */
int* nextGreaterElements(int* nums, int numsSize, int* returnSize) {
    int *ans = (int *)malloc(sizeof(int) * numsSize);
    memset(ans, -1, sizeof(int) * numsSize);

    // 单调栈
    int stack[numsSize * 2];
    int top = 0;
    memset(stack, 0, sizeof(stack));
    for (int i = 0; i < numsSize * 2; i++) {
        while (top > 0 && nums[i % numsSize] > nums[stack[top - 1]]) {
            // 找到第一个比栈顶元素大的数值
            ans[stack[top - 1]] = nums[i % numsSize];
            top--;
        }
        stack[top] = i % numsSize;
        top++;
    }
    *returnSize = numsSize;
    return ans;
}

今日收获

  1. 单调栈
相关推荐
_OP_CHEN12 分钟前
【算法基础篇】(五十七)线性代数之矩阵乘法从入门到实战:手撕模板 + 真题详解
线性代数·算法·矩阵·蓝桥杯·c/c++·矩阵乘法·acm/icpc
天天爱吃肉821817 分钟前
【跨界封神|周杰伦×王传福(陶晶莹主持):音乐创作与新能源NVH测试,底层逻辑竟完全同源!(新人必看入行指南)】
python·嵌入式硬件·算法·汽车
im_AMBER17 分钟前
Leetcode 114 链表中的下一个更大节点 | 删除排序链表中的重复元素 II
算法·leetcode
xhbaitxl30 分钟前
算法学习day38-动态规划
学习·算法·动态规划
多恩Stone30 分钟前
【3D AICG 系列-6】OmniPart 训练流程梳理
人工智能·pytorch·算法·3d·aigc
历程里程碑33 分钟前
普通数组----轮转数组
java·数据结构·c++·算法·spring·leetcode·eclipse
pp起床34 分钟前
贪心算法 | part02
算法·leetcode·贪心算法
sin_hielo34 分钟前
leetcode 1653
数据结构·算法·leetcode
2501_9011478336 分钟前
面试必看:优势洗牌
笔记·学习·算法·面试·职场和发展
YuTaoShao1 小时前
【LeetCode 每日一题】3634. 使数组平衡的最少移除数目——(解法二)排序 + 二分查找
数据结构·算法·leetcode