单调栈的经典例题

前言算法中的单调栈应用十分的广泛;单调栈简单的来说就是栈内元素单调递增或者单调递减的栈,同时单调栈还可以不断的维护一组某种或多种规律的数据,利用这一性质可以解决许多算法问题。本文主要讲解单调栈的算法用法,需对单调栈具有一定的了解。问题描述问题一给你一个字符串 s ,一个整数 k ,一个字母 letter 以及另一个整数 repetition 。返回 s 中长度为 k 且 字典序最小 的子序列,该子序列同时应满足字母 letter 出现 至少 repetition 次。生成的测试用例满足 letter 在 s 中出现至少 repetition 次。子序列 是由原字符串删除一些(或不删除)字符且不改变剩余字符顺序得到的剩余字符串。字符串 a 字典序比字符串 b 小的定义为:在 a 和 b 出现不同字符的第一个位置上,字符串 a 的字符在字母表中的顺序早于字符串 b 的字符。样例:输入:s = "leetcode", k = 4, letter = "e", repetition= 2输出:"ecde"解释:"ecde" 是长度为 4 且满足字母 "e" 出现至少 2 次的字典序最小的子序列。题目来源 力扣:5893. 含特定字母的最小子序列https://leetcode-cn.com/problems/smallest-k-length-subsequence-with-occurrences-of-a-letter/题目分析题意:此题主要描述的是需要维护一个长度为k的字典序最小且至少出现repetition 次letter字母的s的子序列,关键词就是维护一个长度为k的字典序最小的子序列,子序列中包含至少repetition 个letter字母;此题的正好符合单调栈的性质,利用单调栈来维护以上性质!维护三种性质:性质1:维护字典序单增的字符串。(满足题意中的字典序最小这一性质)性质2:维护长度为k的字符串。(满足题中长度为k的字符串这一性质)性质3:维护子序列中包含至少repetition 个letter字母。(同理满足题意性质)const int N = 50010;class Solution {public:int cnt[N];string  smallestSubsequence(string s, int k, char letter, int repetition) {int n = s.size();for (int i = n-1; i >=  0; i --){if (s[i] == letter)  cnt[i] = cnt[i + 1] + 1;else cnt[i] = cnt[i+1];//cnt[i]统计在i的右侧还有多少个letter,便于后续维护}string ans;int p = 0; // p用于记录当前维护字符串中的letter数量// 单调栈模板for (int i = 0; i < n; i  ++){char c = s[i];// 维护字典序单调增的字符串while(!ans.empty()  && c < ans.back()){// 维护长度为不低于k的字符串if (ans.size() - 1  + n - i < k) break;if (ans.back() ==  letter){// 维护子序列中包含至少repetition  个letter字母if (p - 1 +  cnt[i] < repetition) break;p --;}ans.pop_back();}if (c == letter) p ++,  cnt[i] --;ans.push_back(c);}// 因为最终维护的字符串为长度不低于k的字符串,其长度可能超过k,故此将其长度缩减至kwhile(ans.size() > k) {if (ans.back() ==  letter) p --;ans.pop_back();}// 在缩减至k的操作过程中,可能将letter减去,导致字符串中的letter个数少于repetition// 所以如果letter个数少于repetition需要将字符串的末尾值换位letter即可满足for (int i = ans.size() -  1; i >= 0; i --){if (p < repetition  && ans[i] != letter) {ans[i] = letter;p ++;}}return ans;}};问题二返回 s 字典序最小的子序列,该子序列包含 s 的所有不同字符,且只包含一次。样例输入:s ="cbacdcbc"输出:"acdb"题目来源 力扣:1081. 不同字符的最小子序列https://leetcode-cn.com/problems/smallest-subsequence-of-distinct-characters/题目分析此题与上一题类似,求一个最小字典序的子序列,且子序列的必须包含s中所有不同的字符只包含一次。维护二种性质:性质一:维护一个字典序最小的子序列。性质二:维护包含所有不同字符且只包含一次的子序列。class Solution {public:// cnt记录在s中从i向右中还存在的多少个对应字符int cnt[28];// snt记录字符在维护的字符串中是否存在bool snt[28];string  smallestSubsequence(string s) {string t;int n = s.size(), k = 0;for (int i = n-1; i >=  0; i --){int x = s[i] - 'a';if (cnt[x] == 0) k ++;cnt[x] ++;}for (int i = 0; i < n; i  ++){char c = s[i];int u = c - 'a';// 维护最小字典序的子序列while(!t.empty()  && t.back() > c) {int x = t.back() -  'a';// 维护包含所有不同字符且只包含一次的子序列if (cnt[x] <= 0  || snt[u]) break;t.pop_back();snt[x] = false;}if (!snt[u])  t.push_back(c);snt[u] = true, cnt[u]  --;}return t;}};结语稿件来源:深度学习与文旅应用实验室(DLETA)

(0)

相关推荐

  • Python教程:for循环语句

    循环(loop)是生活中常见的现象,如每天的日升日落,斗转星移,都是循环,编程语言的出现就是为了解决现实中的问题,所以也少不了要循环. for循环 在这里我用一个例子来具体解析一下for循环: > ...

  • Python基础知识汇总(避坑)

    (1)字符串(全部返回的都是新的字符串,字符串属于有序不可变序列) s.replace(old,new,[max]) s.strip('a'):从字符串前后剔除字符串'a' s.lstrip('a') ...

  • Python学习手册(第4版).4

    要表示字符串 Bob said "I'm OK". 由于 ' 和 " 会引起歧义,因此,我们在它前面插入一个\表示这是一个普通字符,不代表字符串的起始,因此,这个字符串又 ...

  • Python有哪些函数?Python基础

    Python常用函数有哪些?我想大家都比较好奇这个问题,今天特地整理了一篇有关Python常用函数的相关内容,接下来我们一起来看看具体的内容介绍吧. 1. print()函数:打印字符串; 2. ra ...

  • 搞定Python的几个常用数据结构!

    作者:成了精的柴 来源:https://blog.csdn.net/qq_53421929/ python基本数据类型 数字类型 具体运算中数据的类型 不同情况下的布尔类型 各进制的表示与转换 进制的 ...

  • Python支持哪些数据类型?六大类!

    Python支持哪些数据类型呢?Python基本数据类型分为数字.字符串.列表.元组.字典.集合等六种基本数据类型.接下来,我们一起来看看详细的介绍吧. 数字:数字类型是不可更改的对象.对变量改变的数 ...

  • 100道核心Python面试题,已整理完,小白必看必学

    100道Python面试题整理 大家好,俺是智慧与帅气并存的小编,应一些小伙伴的要求把Python一些核心的面试题整理出来啦. 前言 花了一点时间,整理了这个面试题卡,也是希望对大家有帮助,其实学习君 ...

  • 01 | 栈:从简单栈到单调栈,解决经典栈问题

    今天我们开始学习一个在工作,以及面试中经常被问到的一个数据结构--栈. 栈这种数据结构,在计算机中有着广泛地运用,比如编程语言中函数的调用.操作系统中从用户态到内核态寄存器的保存.网络消息的处理等都会 ...

  • 初中数学:二次根式的考点解析 常见误区 隐含条件 经典例题

    成才路上 初中精品学习资料 104篇原创内容 公众号 二次根式是初中数学的一个重要内容,要求了解二次根式和最简二次根式的概念,理解二次根式的性质,熟练地进行二次根式的加减乘除及混合运算. 今天方法君就 ...

  • 高考物理11类重点题型全解析! 附经典例题&详解

    高考理科综合卷中,物理部分选择题有单项和双项选择题两种题型.从最近几年的试题看: 4道单项选择难度低,考查的考点相对稳定且相对单一,涉及的知识点主要有共点力平衡.热力学第一定律.气体状态方程.分子动理 ...

  • 初中物理杠杆、滑轮知识精讲与经典例题,不可错过!

    END 今天小编倾情推荐初中生学习必备公众号 平台每日免费分享海量学习资料,和备考技巧 内容覆盖全学科.全年级同步课程 切实保障孩子们在暑期学习的效率 希望在孩子学习道路上"助一臂之力&qu ...

  • 高中地理:必考大气运动专项丨知识规律 答题技巧 经典例题详解

    高中地理学科的大气运动专项,几乎是历年高考的重要考点,可以说是高考必考的内容. 在学习大气运动专项时,学姐建议大家从以下重要方向掌握: 热力环流,海陆风.山风谷风.城市郊区风,气压带风带,等压线和风, ...

  • 中考数学几何模型之【半角模型】经典例题解析

    定义 半角模型是指:从正方形的一个顶点引出夹角为45°的两条射线,并连结它们与该顶点的两对边的交点构成的基本平面几何模型. 由于两射线的夹角是正方形一个内角的一半,故名半角模型,又称"角含半 ...

  • 初中数学动点经典例题

    专题一 建立动点问题函数解析式 函数揭示了运动变化过程中量与量之间的变化规律是初中数学的重要内容. 动点问题反映的是一种函数思想,由于某一个点或某图形的有条件地运动变化,引起未知量与已知量间的一种变化 ...

  • 初中数学二次根式的考点解析、常见误区、隐含条件、经典例题

    二次根式是初中数学的一个重要内容,要求了解二次根式和最简二次根式的概念,理解二次根式的性质,熟练地进行二次根式的加减乘除及混合运算. 今天就给大家整理了二次根式的考点,常见的误区,隐藏条件以及常见的例 ...

  • 初中数学:相似三角形13大知识点 6大常考经典例题解析

    初中数学:相似三角形13大知识点 6大常考经典例题解析