【C/C++】每日温度 [ 栈的应用 ] 蓝桥杯/ACM备赛

数据结构考点:栈

题目描述:

给定一个整数数组 temperatures ,表示每天的温度,返回一个数组 answer ,其中 answer[i] 是指对于第 i 天,下一个更高温度出现在几天后。如果气温在这之后都不会升高,请在该位置用 0 来代替。

输入输出描述:

|-----|--------------------------------------------|---------------------|
| | 输入 | 输出 |
| 示例1 | temperatures = [73,74,75,71,69,72,76,73] | [1,1,4,2,1,1,0,0] |
| 示例2 | temperatures = [30,40,50,60] | [1,1,1,0] |
| 示例3 | temperatures = [30,60,90] | [1,1,0] |

详细解答:

解答一:一种会超时的简单算法,不用"栈"

cpp 复制代码
int* dailyTemperatures(int* temperatures, int temperaturesSize, int* returnSize) {
    int *result,flag;
    result = (int*)malloc(sizeof(int) * temperaturesSize);
    returnSize = (int*)malloc(sizeof(int));
    *returnSize = temperaturesSize;
    for (int i = 0; i < temperaturesSize;i++)
    {
        flag = 0;
        int t = temperatures[i];
        for (int j = 1; j <= temperaturesSize-1-i;j++)
        {
            if(t<temperatures[i+j])
            {
                result[i] = j;
                flag = 1;
                break;
            }
        }
        if(flag==0)
            result[i] = 0;
    }
    return result;
}

解法二:利用"栈"

(由于题目来源于Leetcode,所以没有主函数)

该程序以C语言为主,利用了C++的一些函数:(但是不可以再Leetcode提交)

cpp 复制代码
#include<stdio.h>
#include<iostream>
#include<stack>
#include<stdc++.h>
using namespace std;
int* dailyTemperatures(int* temperatures, int temperaturesSize, int* returnSize) {
    int *result;
    result = (int*)malloc(sizeof(int) * temperaturesSize);
    memset(result, 0, sizeof(int) * temperaturesSize);
    *returnSize = temperaturesSize;
    stack<int> sta;
    sta.push(0);
    int i, j;
    for (i = 1;i<temperaturesSize;i++)
    {
        if(temperatures[sta.top()]<temperatures[i])
        {
            while(!sta.empty()&&temperatures[sta.top()]<temperatures[i])
            {
                result[sta.top()] = i - sta.top();
                sta.pop();
            }
            sta.push(i);
        }
        else 
        {
            sta.push(i);
        }
    }
    return result;
}

解法三:C++

cpp 复制代码
class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {

    vector<int> result(temperatures.size(), 0);
    stack<int> sta;
    sta.push(0);
    int i, j;
    for (i = 1;i<temperatures.size();i++)
    {
        if(temperatures[sta.top()]<temperatures[i])
        {
            while(!sta.empty()&&temperatures[sta.top()]<temperatures[i])
            {
                result[sta.top()] = i - sta.top();
                sta.pop();
            }
            sta.push(i);
        }
        else 
        {
            sta.push(i);
        }
    }
    return result;

    }
};

题目来源:Leetcode739.【 739. 每日温度 - 力扣(LeetCode)

相关推荐
rchmin20 小时前
限流算法:令牌桶与漏桶详解
算法·限流
小北方城市网20 小时前
第1课:架构设计核心认知|从0建立架构思维(架构系列入门课)
大数据·网络·数据结构·python·架构·数据库架构
leoufung20 小时前
LeetCode 221:Maximal Square 动态规划详解
算法·leetcode·动态规划
黑符石20 小时前
【论文研读】Madgwick 姿态滤波算法报告总结
人工智能·算法·机器学习·imu·惯性动捕·madgwick·姿态滤波
源代码•宸20 小时前
Leetcode—39. 组合总和【中等】
经验分享·算法·leetcode·golang·sort·slices
好易学·数据结构20 小时前
可视化图解算法77:零钱兑换(兑换零钱)
数据结构·算法·leetcode·动态规划·力扣·牛客网
还债大湿兄20 小时前
huggingface.co 下载有些要给权限的模型 小记录
开发语言·前端·javascript
bkspiderx20 小时前
C++中的map容器:键值对的有序管理与高效检索
开发语言·c++·stl·map
AlenTech20 小时前
226. 翻转二叉树 - 力扣(LeetCode)
算法·leetcode·职场和发展
Hard but lovely20 小时前
Linux: 线程同步-- 基于条件变量 &&生产消费模型
linux·开发语言·c++