整理去临近大小写字符串001

2024-04-13 11:58

本文主要是介绍整理去临近大小写字符串001,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、描述

1544给你一个由大小写英文字母组成的字符串 s 。

一个整理好的字符串中,两个相邻字符 s[i] 和 s[i + 1] 不会同时满足下述条件:

0 <= i <= s.length - 2
s[i] 是小写字符,但 s[i + 1] 是相同的大写字符;反之亦然 。
请你将字符串整理好,每次你都可以从字符串中选出满足上述条件的 两个相邻 字符并删除,直到字符串整理好为止。

请返回整理好的 字符串 。题目保证在给出的约束条件下,测试样例对应的答案是唯一的。

注意:空字符串也属于整理好的字符串,尽管其中没有任何字符。

示例 1:

输入:s = “leEeetcode”
输出:“leetcode”
解释:无论你第一次选的是 i = 1 还是 i = 2,都会使 “leEeetcode” 缩减为 “leetcode” 。
示例 2:

输入:s = “abBAcC”
输出:""

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/make-the-string-great
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2、关键字

字符串单个整理,两个相邻作比较

3、思路

用栈把字符串中的字符一个一个的检查存起来

4、notes

1、题意有点恶心,不过翻译过来就好了,这个0 <= i <= s.length - 2,可以在草纸上画一下就知道了。
2、for循环(语句)一定要遍历到最后一个。
3、if(a条件|| b 条件), 分开写不容易错
4、if else 和if else if else的逻辑注意多考录一下
5、判断两个字符是否一个大写,一个小写.
(c1 ^ c2) == 32
但是如果是a和B就不是33了而是35,这种方法只能比较大写和小写??
6、字符串的ss.back()这个函数不能直接取出来字符进行位运算,但是可以取出来字符进行数字运算服了,第二个代码有展示

5、复杂度

时间:O(n):遍历整个字符串,
空间:O(N)整个栈空间是o(N)的复杂度

6、code

class Solution {
public:string makeGood(string s) {stack<char>v1,res;  // 定义两个栈string ss;  // 结果集int size=s.size();/* for(int i=0;i<size;i++)  // 这个也可以{if(v1.empty() ){v1.push(s[i]);}else if(abs(s[i]-v1.top())==32 ){v1.pop();}else{v1.push(s[i]);}}*/for(auto tem : s){  // 遍历整个字符串if(v1.empty() )  // 如果为空就进栈{v1.push(tem);}else if(abs(tem-v1.top())==32 )  // 如果当前字符串的元素和栈顶元素相同就出栈{v1.pop();}else  // 正常进栈{v1.push(tem);}}while(!v1.empty())  // 把倒序的结果字符转成正序的{res.push(v1.top());v1.pop();}while(!res.empty()){ss+=res.top();res.pop();}return ss;}
};

直接用string 来存结果

class Solution {
public:string makeGood(string s) {string ss;int size=s.size();for(auto tem:s){if(ss.empty()){ss.push_back(tem);}else if(abs(ss.back()-tem)==32)//else if(ss.back()^tem==32) // 这么写就过不去ss.pop_back();elsess.push_back(tem);}return ss;}
};

这篇关于整理去临近大小写字符串001的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/900077

相关文章

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

python中字符串拼接的几种方法及优缺点对比详解

《python中字符串拼接的几种方法及优缺点对比详解》在Python中,字符串拼接是常见的操作,Python提供了多种方法来拼接字符串,每种方法有其优缺点和适用场景,以下是几种常见的字符串拼接方法,需... 目录1. 使用 + 运算符示例:优缺点:2. 使用&nbsjsp;join() 方法示例:优缺点:3

Mysql中深分页的五种常用方法整理

《Mysql中深分页的五种常用方法整理》在数据量非常大的情况下,深分页查询则变得很常见,这篇文章为大家整理了5个常用的方法,文中的示例代码讲解详细,大家可以根据自己的需求进行选择... 目录方案一:延迟关联 (Deferred Join)方案二:有序唯一键分页 (Cursor-based Paginatio

java字符串数字补齐位数详解

《java字符串数字补齐位数详解》:本文主要介绍java字符串数字补齐位数,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java字符串数字补齐位数一、使用String.format()方法二、Apache Commons Lang库方法三、Java 11+的St

C++字符串提取和分割的多种方法

《C++字符串提取和分割的多种方法》在C++编程中,字符串处理是一个常见的任务,尤其是在需要从字符串中提取特定数据时,本文将详细探讨如何使用C++标准库中的工具来提取和分割字符串,并分析不同方法的适用... 目录1. 字符串提取的基本方法1.1 使用 std::istringstream 和 >> 操作符示

C语言字符函数和字符串函数示例详解

《C语言字符函数和字符串函数示例详解》本文详细介绍了C语言中字符分类函数、字符转换函数及字符串操作函数的使用方法,并通过示例代码展示了如何实现这些功能,通过这些内容,读者可以深入理解并掌握C语言中的字... 目录一、字符分类函数二、字符转换函数三、strlen的使用和模拟实现3.1strlen函数3.2st

Java反转字符串的五种方法总结

《Java反转字符串的五种方法总结》:本文主要介绍五种在Java中反转字符串的方法,包括使用StringBuilder的reverse()方法、字符数组、自定义StringBuilder方法、直接... 目录前言方法一:使用StringBuilder的reverse()方法方法二:使用字符数组方法三:使用自

Golang中拼接字符串的6种方式性能对比

《Golang中拼接字符串的6种方式性能对比》golang的string类型是不可修改的,对于拼接字符串来说,本质上还是创建一个新的对象将数据放进去,主要有6种拼接方式,下面小编就来为大家详细讲讲吧... 目录拼接方式介绍性能对比测试代码测试结果源码分析golang的string类型是不可修改的,对于拼接字

Mysql中InnoDB与MyISAM索引差异详解(最新整理)

《Mysql中InnoDB与MyISAM索引差异详解(最新整理)》InnoDB和MyISAM在索引实现和特性上有差异,包括聚集索引、非聚集索引、事务支持、并发控制、覆盖索引、主键约束、外键支持和物理存... 目录1. 索引类型与数据存储方式InnoDBMyISAM2. 事务与并发控制InnoDBMyISAM