145.栈和队列:删除字符串中的所有相邻重复项(力扣)

题目描述

代码解决

class Solution {
public:string removeDuplicates(string s) {// 定义一个栈来存储字符stack<char> st;// 遍历字符串中的每一个字符for(int i = 0; i < s.size(); i++){// 如果栈为空或栈顶字符与当前字符不相同,则将当前字符入栈if(st.empty() || st.top() != s[i]){st.push(s[i]);}// 如果栈顶字符与当前字符相同,则弹出栈顶字符,表示删除这两个重复的字符else{st.pop();}}// 定义结果字符串string result = "";// 将栈中剩余的字符依次弹出,形成结果字符串while(!st.empty()){result += st.top();st.pop();}// 由于栈弹出顺序是逆序的,所以需要将结果字符串反转reverse(result.begin(), result.end());// 返回最终的结果字符串return result;}
};
  1. 定义栈

    • stack<char> st;
    • 使用栈来存储字符,方便检查和删除相邻且重复的字符。
  2. 遍历字符串

    • for(int i = 0; i < s.size(); i++)
    • 遍历字符串的每一个字符。
  3. 处理字符

    • if(st.empty() || st.top() != s[i])
      • 如果栈为空或者栈顶字符与当前字符不相同,则将当前字符入栈。
    • else { st.pop(); }
      • 如果栈顶字符与当前字符相同,则弹出栈顶字符,表示删除这两个重复的字符。
  4. 构建结果字符串

    • string result = "";
    • 定义一个结果字符串,用于存储栈中的字符。
  5. 将栈中的字符弹出并添加到结果字符串中

    • while(!st.empty()) { result += st.top(); st.pop(); }
    • 将栈中剩余的字符依次弹出,形成结果字符串。
  6. 反转结果字符串

    • reverse(result.begin(), result.end());
    • 由于栈的弹出顺序是逆序的,所以需要将结果字符串反转。
  7. 返回最终结果

    • return result;
    • 返回处理后的字符串。

代码解决二 

class Solution {
public:string removeDuplicates(string s) {// 定义一个字符串变量result,用于存储处理后的字符string result;// 遍历输入字符串s中的每一个字符for(char a : s){// 如果result为空或result的最后一个字符与当前字符a不相同,则将字符a添加到result的末尾if(result.empty() || result.back() != a){result.push_back(a);}// 如果result的最后一个字符与当前字符a相同,则将result的最后一个字符删除else{result.pop_back();}}// 返回处理后的字符串resultreturn result;}
};
  1. 定义结果字符串

    • string result;
    • 使用一个字符串变量 result 来存储处理后的字符。
  2. 遍历输入字符串

    • for(char a : s)
    • 遍历输入字符串 s 中的每一个字符 a
  3. 处理字符

    • if(result.empty() || result.back() != a)
      • 如果 result 为空或者 result 的最后一个字符与当前字符 a 不相同,则将字符 a 添加到 result 的末尾。
    • else { result.pop_back(); }
      • 如果 result 的最后一个字符与当前字符 a 相同,则将 result 的最后一个字符删除。
  4. 返回最终结果

    • return result;
    • 返回处理后的字符串 result

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

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

相关文章

抖音小店怎么快速出体验分?为什么销量过30单还没有体验分?

大家好&#xff0c;我是喷火龙。 体验分不管对于新店铺还是老店铺都是非常重要的&#xff0c;因为体验分直接影响着我们店铺的流量&#xff0c;特别是新手商家&#xff0c;做店的第一步就是要把体验分迅速的拉起来。 新店出体验分有一个要求&#xff0c;就是店铺的销量要满足…

Dockerfile使用

1.Dockerfile是什么 官网地址 https://docs.docker.com/reference/dockerfile/概念 是什么 Dockerfile 是用于构建 Docker 镜像的文本文件&#xff0c;它包含一系列的指令&#xff08;instructions&#xff09;和参数&#xff0c;用于描述如何构建和配置镜像。 Dockerfile 是…

【CTF Web】NSSCTF 3868 [LitCTF 2023]这是什么?SQL !注一下 !Writeup(SQL注入+报错注入+括号闭合+DIOS)

[LitCTF 2023]这是什么&#xff1f;SQL &#xff01;注一下 &#xff01; 为了安全起见多带了几个套罢了o(▽)q 出题人 探姬 解法 先试试这个&#xff1a; )))))) or 11 -- 有结果了&#xff0c;但是这个 flag 是假的。 flag 可能在其他表里。用 hackbar 上 DIOS payload。 …

深入学习 torch.distributions

0. 引言 前几天分几篇博文精细地讲述了《von Mises-Fisher 分布》, 以及相应的 PyTorch 实现《von Mises-Fisher Distribution (代码解析)》, 其中以 Uniform 分布为例简要介绍了 torch.distributions 包的用法. 本以为已经可以了, 但这两天看到论文 The Power Spherical dist…

HarmonyOS interface router scale pageTransition SlideEffect.Left ArkTS ArkUI

&#x1f3ac;️create Component export default struct TitleBar {build(){Row(){Text(transition).fontSize(30fp).fontColor(Color.White)}.width(100%).height(8%).backgroundColor(#4169E1).padding({left:10})}}&#x1f39e;️interface export interface IList{ti…

20240528解决飞凌的OK3588-C的核心板的TYPE-C1接口识别问题

20240528解决飞凌的OK3588-C的核心板的TYPE-C1接口识别问题 2024/5/28 16:46 缘起&#xff1a; 现阶段碰到的USB相关的问题&#xff1a;&#xff08;LINUX R4版本&#xff09; 1、USB3.0插USB摄像头 lsusb找不到设备 2、刷机口只接了3根线&#xff0c;GND/D/D-&#xff0c;可以…

[STM32+HAL]LD-1501MG舵机二次开发指南

一、准备材料 核心板&#xff1a;STM32F407ZGT6 舵机&#xff1a;LD-1501MG数字舵机 控制器&#xff1a;24路PWM舵机控制器 二、HAL库配置 开启串口与控制器通信 三、Keil填写代码 1、Servo.c #include "Servo.h" #include "usart.h"uint8_t Message…

人生二选一:央企就业?美国做博士后?—请看她的抉择

一位30岁的女博士&#xff0c;收到国内央企和德国、美国的博士后邀请函&#xff0c;她该如何选择&#xff1f;知识人网小编推荐这篇文章&#xff0c;为大家解开谜题的同时&#xff0c;也给有同样纠结的学者提供一些启迪。 去年12月底的一个晚上&#xff0c;我收到美国一所高校发…

极致产品力|从toB到toC,年销4.2亿份的冻干品牌是如何炼成的?

天野食品是日本冻干食品长红40年的品牌&#xff0c;从制造焦糖的小工厂&#xff0c;转变为日本冻干速食的行业第一&#xff0c;它是如何做到的呢? 深耕TOB业务&#xff0c;如何在ToC业务创造增长 天野公司以冻干食品闻名但并非以此起家。自1940年成立以来&#xff0c;便以染料…

Windows:iHasher-v0.2安装报错Windows 功能 .NET Framework 3.5

一、情景描述 我们从MSDN下载了镜像文件&#xff0c;一般要验证下载文件的HASH值是否与MSDN上发布的一致&#xff0c;确保传出过程中iso文件没有损坏。 MSDN地址&#xff1a;https://msdn.itellyou.cn/ 我从MSDN下载了Hasher工具&#xff0c;进行校验。 但是&#xff0c;安装…

2024年5月软考成绩什么时候出?附查询方式

2024年5月软考成绩查询时间及查询方式&#xff1a; 查询时间&#xff1a;预计在2024年7月上旬进行。 查询方式&#xff1a; 方式一&#xff1a;登陆中国计算机技术职业资格网&#xff08;www.ruankao.org.cn&#xff09;&#xff0c;点击报名系统&#xff0c;输入注册账号和…

Vue3实战笔记(35)—集成炫酷的粒子特效

文章目录 前言一、vue3使用tsparticles二、使用步骤总结 前言 学习一个有趣炫酷的玩意开心一下。 tsparticles&#xff0c;可以方便的实现各种粒子特效。支持的语言框架也是相当的丰富. 官网&#xff1a;https://particles.js.org/ 一、vue3使用tsparticles 先来个vue3使用…

从华为云OBS到AWS云上S3:迁移及相关事项

随着云计算的快速发展&#xff0c;企业越来越倾向于将数据存储和管理移到云端。华为云的对象存储服务&#xff08;OBS&#xff09;和亚马逊云服务&#xff08;AWS&#xff09;上的简单存储服务&#xff08;S3&#xff09;是两个备受欢迎的选择。对于那些考虑从华为云OBS迁移到A…

K8S中Prometheus+Grafana监控

1.介绍 phometheus:当前一套非常流行的开源监控和报警系统。 运行原理&#xff1a;通过HTTP协议周期性抓取被监控组件的状态。输出被监控组件信息的HTTP接口称为exporter。 常用组件大部分都有exporter可以直接使用&#xff0c;比如haproxy,nginx&#xff0c;Mysql,Linux系统信…

七大获取免费https的方式

想要实现https访问最简单有效的的方法就是安装SSL证书。只要证书正常安装上以后&#xff0c;浏览器就不会出现网站不安全提示或者访问被拦截的情况。下面我来教大家怎么去获取免费的SSL证书&#xff0c;又如何安装证书实现https访问。 一、选择免费SSL证书提供商 有多家机构提…

第53期|GPTSecurity周报

GPTSecurity是一个涵盖了前沿学术研究和实践经验分享的社区&#xff0c;集成了生成预训练Transformer&#xff08;GPT&#xff09;、人工智能生成内容&#xff08;AIGC&#xff09;以及大语言模型&#xff08;LLM&#xff09;等安全领域应用的知识。在这里&#xff0c;您可以找…

Spring MVC实战练习

本实战练习是关于Spring MVC框架的应用&#xff0c;通过一系列的任务来学习如何使用Spring MVC开发Web应用程序。Spring MVC是Spring框架的一个模块&#xff0c;用于构建Web应用程序的模型-视图-控制器&#xff08;MVC&#xff09;架构。 任务1&#xff1a;新建项目首页 修改…

HTML大雪纷飞

目录 写在前面 HTML简介 完整代码 代码分析 运行结果 系列文章 写在后面 写在前面 小编又又又出现啦&#xff01;这次小编给大家带来大雪纷飞HTML版&#xff0c;不需要任何的环境&#xff0c;只要有一个浏览器&#xff0c;就可以随时随地下一场大雪哦&#xff01; HTM…

工商银行异地卡兑换泰铢的流程

本文介绍在国内的工商银行&#xff0c;通过现金或银行卡兑换泰国铢等外国货币的纸币或硬币的方法。 最近&#xff0c;准备到泰国旅行&#xff0c;所以需要兑换一些泰铢&#xff0c;防止下飞机到当地后找不到汇率合适、兑换方便的换钱的地方。其中&#xff0c;因为对比发现工商银…

01-05.Vue自定义过滤器

目录 前言过滤器的概念过滤器的基本使用给过滤器添加多个参数 前言 我们接着上一篇文章01-04.Vue的使用示例&#xff1a;列表功能 来讲。 下一篇文章 02-Vue实例的生命周期函数 过滤器的概念 概念&#xff1a;Vue.js 允许我们自定义过滤器&#xff0c;可被用作一些常见的文本…