stack(leetcode练习题)

文章目录

  • STL用法总结
    • 32 最长有效括号
      • 思路
      • 代码
    • 496 下一个最大元素
      • 思路
      • 代码
    • 856 括号的分数
      • 思路

STL用法总结

关于stack的知识,可以看点击查看上面的博客,以下题目全在leetcode

32 最长有效括号

在这里插入图片描述

思路

“(()”
“()(()”
“(()(((()”
最开始写的,总会有一些样例过不了,没考虑全,后来看题解上的方法,将下标压入栈中,用右括号的下标减去栈顶下标,就是有效长度。看来那位讲题同学说的,先忽略最长是有道理。不然只顾着最长,反而无法得到正确的有效长度。

代码

  class Solution {
public:int longestValidParentheses(string s) {stack<int> k;int l=0,r=0,ans=0 ;k.push(-1);//初始化,压栈for(int i=0;i<s.size();i++){if(s[i]=='('){k.push(i);}else{k.pop();if(k.empty())k.push(i);elseans=max(ans,i-k.top());}}return ans;}
};

496 下一个最大元素

在这里插入图片描述

思路

运用栈,可以很好解决。要找下一个最大元素。可以将数组倒着入栈。如果数字比栈顶小就压入,否则,将栈顶删除直到,比栈顶小或这栈为空。此时栈顶就是答案,为空则标记为-1;

代码

class Solution {
public:int a[10050];vector<int> nextGreaterElement(vector<int>& nums1,          vector<int>& nums2) {stack<int> k;vector<int> v;for(int i=nums2.size()-1;i>=0;i--){while(!k.empty()&&nums2[i]>=k.top()){k.pop();}if(k.size()==0) a[nums2[i]]=-1;else a[nums2[i]]=k.top();k.push(nums2[i]);}for(int i=0;i<nums1.size();i++)v.push_back(a[nums1[i]]);return v;}
};

856 括号的分数

在这里插入图片描述

思路

一个完整的括号,要么是1,要么里边包含其他括号,进行了 *2。所以,可以每遇到一个右括号,进行一次运算,第一次为 1,以后每次乘二,累加到栈顶。遇到左括号,就向栈压入0,重新运算,当遇到右括号,再弹出.

class Solution {
public:int scoreOfParentheses(string s) {stack<int> k;k.push(0);//先推入0,防止k为空for (int i=0;i<s.size();i++) {if (s[i] == '(') {k.push(0);} else {int v = k.top();k.pop();k.top() += max(2 * v, 1);}}return k.top();}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/48091.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux下docker快速安装gitea

之前在服务器上装的gitlab来管理个人项目&#xff0c;但是gitlab服务启动后能明显感受到占用资源比较严重。最近服务器到期&#xff0c;换了个服务器还没来得及装gitlab&#xff0c;刚好最近接触到gitea&#xff0c;网上是这么说的 占用资源少&#xff0c;适合个人开发者&…

[PM]数据分析

概览 数据的定义 运营数据 分析的目的 数据分析流程 1.明确目标 2.数据来源 3.采集数据 4.数据整理 5.数据分析 趋势分析 当数据出现异常&#xff0c;一般从3个角度去查找问题&#xff1a; 1.技术层面&#xff0c;是不统计出错&#xff0c;或者产品出现bug 工 2.产品层面&am…

连接hive库增加相关包

连接hive库增加相关包 例如&#xff1a;java.lang.NoClassDefFoundError: com/ctc/wstx/io/InputBootstrapper org.apache.hadoop.hive.common.auth.HiveAuthUtils java.lang.NoClassDefFoundError: org/codehaus/stax2/XMLInputFactory2

0711springNews新闻系统管理 实现多级评论

0611springmvc新闻系统管理-CSDN博客 0711springNews新闻系统管理项目包 实现多级评论-CSDN博客 数据库字段 需要添加父节点id&#xff0c;通过该字段实现父评论和子评论的关联关系。 对象属性 实现链表&#xff0c;通过一个父评论可以找到它对应的所有子孙评论。 业务层 实现…

Capture软件元件库(以STM32为例)

本教程基于【凡亿】Cadence Allegro 17.4零基础入门66讲PCB Layout设计实战视频 &#xff08;一&#xff09;自带库路径查找 1&#xff0c;首先在找到文件的快捷方式 2&#xff0c;右键打开文件所在位置 3&#xff0c;点击tools&#xff08;上一级目录&#xff09; 4&#xf…

Docker 和 k8s 之间是什么关系?

Docker 简介 Docker 功能&#xff1a; Docker 是一款可以将程序和环境打包并运行的工具软件。通过 Docker&#xff0c;可以将程序及其依赖环境打包&#xff0c;确保在不同操作系统上一致的运行效果。 环境一致性问题&#xff1a; 程序依赖于特定的环境&#xff0c;不同操作系统…

数据库系列

目录 一、数据库的概念和作用 1.数据库的特点 2.数据模型 二、数据库系统 1.数据库管理系统 2.数据库的基本操作 一、数据库的概念和作用 数据库是指长期存储在计算机内&#xff0c;有组织的、可共享的数据集合。它可视为一个电子化的文件柜&#xff0c;用来存储电子文件…

数据库最佳实践:优化爬虫管理的数据存储方案

摘要&#xff1a; 面对日益增长的数据抓取需求&#xff0c;如何高效管理和存储爬虫获取的海量信息成为一大挑战。本文将深入探讨数据库最佳实践&#xff0c;揭示如何通过优化策略提升爬虫数据存储效率&#xff0c;助您跨越数据管理的障碍&#xff0c;实现数据价值最大化。 一、…

Mac上安装Charles 对iPhone进行抓包

Mac上安装Charles 对iPhone进行抓包 Charles 对手机抓包&#xff0c;如果步骤已经完全了但是上不了网&#xff0c;多半是因为证书没有添加信任&#xff0c;需要在两个地方进行设置&#xff1a; 在mac上&#xff0c;启动台>钥匙串访问>找到自己安装的证书 进行设置 ios的…

SpringBoot+Vue(3)Excel的在线预览

一、思路 在Spring Boot和Vue.js的组合中实现Excel文件的在线预览功能&#xff0c;通常涉及到几个关键步骤&#xff1a;文件上传、文件存储、文件读取、以及通过前端展示Excel内容。由于Excel文件本身不是直接可以在网页上渲染的格式&#xff0c;我们通常需要将Excel文件转换为…

SpringMVC源码深度解析(下)

接着上一遍博客《SpringMVC源码深度解析(中)》继续聊。上一篇博客中&#xff0c;返回的是对象的情况下SpringMVC框架会怎么处理&#xff0c;这种情况也是现在用得最多的&#xff0c;因为都是前后端分离。如果返回的是ModelAndView&#xff0c;则是另外的处理逻辑了&#xff0c;…

稀疏支持向量机(Sparse Support Vector Machine, Sparse SVM)

稀疏支持向量机&#xff08;Sparse Support Vector Machine, Sparse SVM&#xff09; 稀疏支持向量机是一种在支持向量机的基础上&#xff0c;通过引入稀疏性约束&#xff0c;使得模型参数更加稀疏&#xff0c;从而提高模型的可解释性和计算效率的方法。以下是稀疏支持向量机的…

CSS3 教程

CSS3 教程 引言 CSS3&#xff0c;即层叠样式表的第三代&#xff0c;是网页设计和开发中不可或缺的技术之一。它为HTML元素提供了丰富的样式定义&#xff0c;使得网页不仅内容丰富&#xff0c;而且外观美观、交互性强。本教程将详细介绍CSS3的基础知识、高级特性以及最佳实践&…

【Spring Boot 中的 `banner.txt` 和 `logback-spring.xml` 配置】

文章目录 一、banner.txt1. 创建自定义 banner.txt2. 配置 banner.txt 的内容 二、logback-spring.xml1. 创建 logback-spring.xml2. 配置 logback-spring.xml 一、banner.txt banner.txt 是 Spring Boot 项目启动时显示的自定义横幅内容。用来展示项目名称、版本信息或者其他…

python实现计数排序、桶排序和基数排序算法

python实现计数排序、桶排序和基数排序算法 计数排序算法步骤&#xff1a; Python实现计数排序桶排序算法步骤&#xff1a; Python实现桶排序基数排序算法步骤&#xff1a; Python实现基数排序算法时间复杂度 计数排序 计数排序是一种非比较排序算法&#xff0c;适用于元素范围…

数据仓库中事实表设计的关键步骤解析

在数据仓库的设计过程中&#xff0c;事实表是描述业务度量的核心组件。本文将深入探讨数据仓库中事实表设计的关键步骤&#xff0c;包括选择业务过程及确定事实表类型、声明粒度、确定维度和确定事实的过程&#xff0c;帮助读者更好地理解和应用事实表设计的原则和方法。 第一…

Ideal窗口中左右侧栏消失了

不知道大家在工作过程中有没有遇到过此类问题&#xff0c;不论是Maven项目还是Gradle项目&#xff0c;突然发现Ideal窗口右侧图标丢失了&#xff0c;同事今天突然说大象图标不见了&#xff0c;不知道怎样刷新gradle。 不要慌张&#xff0c;下面提供一些解决思路&#xff1a; 1…

【C语言ffmpeg】打开第一个视频

文章目录 前言须知ffmpeg打开文件基本流程图ffmpeg打开媒体文件AVFormatContext *avformat_alloc_context(void);AVFormatContext 成员变量及其作用AVInputFormat *iformatAVOutputFormat *oformatvoid *priv_dataAVIOContext *pbunsigned int nb_streamsAVStream **streamscha…

LeetCode 232.用栈实现队列 C写法

LeetCode 232.用栈实现队列 C写法 思路&#x1f9d0;&#xff1a; 栈代码在本篇中。与队列实现栈类似&#xff0c;不过这里我们建立两个栈&#xff0c;一个栈专门存放入队数据&#xff0c;一个专门存放出队数据&#xff0c;不需要再来回导数据。原理在于一个栈的数据到另一个栈…

Windows右键新建Markdown文件类型配置 | Typora | VSCode

&#x1f64b;大家好&#xff01;我是毛毛张! &#x1f308;个人首页&#xff1a; 神马都会亿点点的毛毛张 今天毛毛张分享的是如何在右键的新建菜单中添加新建MarkdownFile文件&#xff0c;这是毛毛张分享的关于Typora软件的相关知识的第三期 文章目录 1.前言&#x1f3dd;…