当前位置: 首页 > article >正文

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

数据结构考点:栈

题目描述:

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

输入输出描述:

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

详细解答:

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

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提交)

#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++

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)】


http://www.kler.cn/a/540015.html

相关文章:

  • DeepSeek本地部署详细指南
  • 半导体制造工艺讲解
  • 使用Qt+opencv实现游戏辅助点击工具-以阴阳师为例
  • 《深度学习》——pytorch框架及项目
  • JavaScript:还在用if判断属性是否存在?哒咩(?.)用起来
  • C++,STL 迭代器简介:概念、分类、操作
  • SQL自学,mysql从入门到精通 --- 第 1 天,系统环境搭建,mysql部署
  • 小结:VLAN、STP、DHCP、ACL、NAT、PPP、边界路由等配置指令
  • 数据结构 day01
  • 老榕树的Java专题:Redis 从入门到实践
  • 代码笔记:ln创建链接
  • C++20导出模块及使用
  • Day.23
  • 字符设备驱动开发
  • 人工智能领域-CNN 卷积神经网络 性能调优
  • 使用Docker + Ollama在Ubuntu中部署deepseek
  • EXCEL数据解析与加密处理方法
  • Vue Router 导航方式详解:声明式导航与编程式导航
  • flink判断两个事件之间有没有超时(不使用CEP)
  • jmeter 性能测试Linux 常用的安装
  • 设计模式 ->模板方法模式(Template Method Pattern)
  • matlab simulink 船舶模糊pid控制仿真
  • 网络安全行业的冬天
  • 5.攻防世界 fileinclude
  • xss闯关
  • 【深度学习】基于MXNet的多层感知机的实现