栈练习--------(LeetCode 739-每日温度)

题目:点这里

解法

cpp 复制代码
class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {
        vector<int> ans;
        vector<int> stc;
        for(int i=0;i<temperatures.size();i++){
            ans.push_back(0);
        }
        for(int i=0;i<temperatures.size();i++){
            while(stc.size()&&temperatures[stc.back()]<temperatures[i]){
                ans[stc.back()] = i-stc.back();
                stc.pop_back();    
            }   
            stc.push_back(i);
        }
        return ans; 
    }
};

这个题目我又一次被栈这个容器的神奇所深深吸引,栈这个容器真是太有魅力了,同样的一道题目,用循环需要双层嵌套,代码又长又臭,而且会超时,用栈的话巧妙解决这个问题。

具体思路就是,首先定义两个栈,一个用来存放最终的答案,一个用来暂存需要比较元素的索引,第一步咱们将答案栈的所有值赋值为0,然后利用for循环的遍历,先将第一个元素,暂存入stc栈中,然后将温度数组中的后续元素与之比较,如若大于,则将两元素索引差传入答案栈,并且弹出stc栈的栈顶元素,否则将其传入stc栈中,紧接着进入下一层循环,再将stc栈的栈顶元素与后续元素进行比较,与前面重复相同的操作。

图示

但我学到的不只有这些。。。

反思

首先这一大段复杂的难以理解的代码不是一气呵成的,它需要我们结合图像分析,并生成初步的,不完善的一次性代码,后续再进行优化,比如:如果if语句和对应的else语句中都存在相同的语句,则就可以把这个重复语句提出来,放在判断的外面 ,另外,我总感觉栈配合循环 能爆发出无限的潜能,但我现在还不能想像出来,但这个题目给了我一点启发,栈配合循环使用的情形,如果一开始想象不到,可以把栈当作一个缓存的变量使用,结合判断,先写执行一次的特殊性代码,然后再转化成普遍性代码,这个就是从个性到共性,从特殊性到普遍性的道理。

还有,

ret.push_back()代表从尾部插入即入栈

ret.back()代表返回尾部元素即返回栈顶元素

ret.pop_back()代表删除尾部元素即出栈

相关推荐
子一!!1 小时前
数据结构==二叉平衡树,AVL树 ===
数据结构·算法
Mr_Oak1 小时前
【multi-model】DINOv2(包含iBOT)& 问答
图像处理·人工智能·深度学习·算法·多模态·对比学习·视觉大模型
山峰哥1 小时前
从指针到智能体:我与C++的二十年技术进化与AI革命
大数据·开发语言·数据结构·c++·人工智能
mjhcsp1 小时前
P1906 凯撒密码洛谷(mjhcsp)
c++
七夜zippoe1 小时前
轻量模型微调:LoRA、QLoRA实战对比与工程实践指南
人工智能·深度学习·算法·lora·qlora·量化训练
youngee111 小时前
hot100-44从前序与中序遍历构造二叉树
数据结构·算法
im_AMBER1 小时前
Leetcode 68 搜索插入位置 | 寻找比目标字母大的最小字母
数据结构·笔记·学习·算法·leetcode
严文文-Chris1 小时前
【非监督学习常见算法】
学习·算法·机器学习
CoderYanger1 小时前
动态规划算法-斐波那契数列模型:1.第N个泰波那契数
开发语言·算法·leetcode·动态规划·1024程序员节