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

news2025/1/11 9:53:27

题目描述

代码解决

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();
            }
        }
        
        // 返回处理后的字符串result
        return 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.coloradmin.cn/o/1686684.html

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

相关文章

SpringBoot项目中redis序列化和反序列化LocalDateTime失败

实体类中包含了LocalDateTime 类型的属性&#xff0c;把实体类数据存入Redis后变成这样&#xff1a; 此时&#xff0c;存入redis不会报错&#xff0c;但是从redis获取的时候&#xff0c;会报错&#xff1a; com.fasterxml.jackson.databind.exc.InvalidDefinitionException: Ca…

AI - Transformer架构工作原理

一、概述 Transformer是由Vaswani等人在2017年提出的一种基于自注意力机制&#xff08;Self-Attention Mechanism&#xff09;的深度学习网络架构的大模型&#xff0c;被广泛应用于自然语言处理&#xff08;NLP&#xff09;领域&#xff0c;如机器翻译、文本生成等任务。它摒弃…

LabVIEW高温往复摩擦测试系统中PID控制

在LabVIEW开发高温往复摩擦测试系统中实现PID控制&#xff0c;需要注意以下几个方面&#xff1a; 1. 系统建模与参数确定 物理模型建立: 首先&#xff0c;需要了解被控对象的物理特性&#xff0c;包括热惯性、摩擦系数等。这些特性决定了系统的响应速度和稳定性。实验数据获取…

陕西煤矿化工集团如何投稿刊登到央媒

随着信息技术的飞速发展&#xff0c;国家级媒体平台已经成为了众多作者追求发表文章的热门选择。然而&#xff0c;要想在这些平台上成功发表文章&#xff0c;除了具备优秀的文稿质量外&#xff0c;还需要掌握一定的投稿技巧和策略。本文将为您详细介绍国家级媒体投稿方式&#…

samba_ubuntu_share_vmbox_vmware

_____ Ubuntu 利用 samba 与 win 直接共享文件夹 _____ samba Samba - 维基百科&#xff0c;自由的百科全书 (wikipedia.org) 用于 win 和 unix 直接访问资源 samba 为选定的 unix 目录建立网络共享&#xff0c; 使得 win 用户可以像访问普通 win 下的文件夹那样来通过网络来…

Discourse Discover 添加你的网站到 Discourse 官方

discourse discover 应该允许你把你的 Discourse 实例添加到 Discourse 的 https://discover.discourse.org/ 1 页面中。 直接在你网站的配置上搜索 Discourse Discover &#xff0c;余下的工作就可以交给 Discourse 了。 还没有选的&#xff0c;可以马上选上喔。 但显然排序…

Baidu Comate For Xcode 你的AI编程助手

前言 Baidu Comate 基于文心大模型&#xff0c;结合百度编程大数据&#xff0c;为你生成优质编程代码 你的AI编程助手&#xff0c;你的编码效率提升好帮手 Baidu Comate 释放“十倍”软件生产力 一、Xcode 安装配置 Baidu Comate 安装 已安装Xcode的情况下&#xff0c;下载B…

Windows下安装Hadoop(引导版)

Windows下安装Hadoop(引导版) 本环境只作为测试环境的搭建和学习使用 参考文档 环境&#xff1a; 首先确定环境为java1.8 或者hadoop适配的版本 cmd java -version查看 hadoop环境变量可以不用设置 关于hdfs的配置可以自行修改目录 具体的安装方式参考下面的两个文档 下载…

Spring Boot企业级开发教程-第4章Spring Boot视图技术

文章目录 4.1 Spring Boot支持的视图技术4.2 Thymaleaf基本语法常用标签标准表达式1.变量表达式2.选择变量表达式3.消息表达式4.链接表达式5.片段表达式 4.3 Thymaleaf基本使用4.3.1 Thymeleaf模板基本配置4.3.2 静态资源的访问 4.4 使用Thymaleafs完成页面的数据展示4.5 使用T…

Android面试题之Kotlin常见集合操作技巧

本文首发于公众号“AntDream”&#xff0c;欢迎微信搜索“AntDream”或扫描文章底部二维码关注&#xff0c;和我一起每天进步一点点 list 创建和修改 不可变list,listOf var list listOf("a","d","f") println(list.getOrElse(3){"Unkn…

NebulaGraph

文章目录 关于 NebulaGraph客户端支持安装 NebulaGraph关于 nGQLnGQL 可以做什么2500 条 nGQL 示例原生 nGQL 和 openCypher 的关系 Backup&Restore功能 导入导出导入工具导出工具 NebulaGraph ImporterNebulaGraph ExchangeNebulaGraph Spark ConnectorNebulaGraph Flink …

临时工说:为什么成熟的数据库企业都在云上部署产品,并把主要力量放到云上...

开头还是介绍一下群&#xff0c;如果感兴趣PolarDB ,MongoDB ,MySQL ,PostgreSQL ,Redis, Oceanbase, Sql Server等有问题&#xff0c;有需求都可以加群群内有各大数据库行业大咖&#xff0c;可以解决你的问题。加群请联系 liuaustin3 &#xff0c;&#xff08;共2320人左右 1 …

网站笔记:huggingface——can you run it?

Can You Run It? LLM version - a Hugging Face Space by Vokturz 1 配置设置部分 Model Name就是需要测量的模型名称 GPU Vendor ——GPU供应商 Filter by RAM (按RAM过滤) 筛选出所有内存容量在选择范围之间的GPU GPU 下拉菜单选择具体的GPU型号 LoRa % trainable param…

如何用VSCode debug Python文件

诸神缄默不语-个人CSDN博文目录 需求&#xff1a;我其实一般都用print大法来“调试”程序&#xff0c;但是有时对于机械性比较强但是又有些复杂的程序&#xff0c;还是debug比较方便。 debug功能我之前用过NetBeans和eclipse&#xff0c;应该可以明显看出来我是Java转Python党…

做好智慧校园的顶层设计,助力教育信息化发展

教育信息化已被视为我国教育事业发展的重要支撑。随着国家教育信息化一系列重大工程的部署和实施&#xff0c;我国教育信息化进入快速发展时期&#xff0c;取得了显著成绩。我们认识到国家教育信息化正由初步应用融合阶段向着全面融合创新阶段过度&#xff0c;无论从国家地区的…

上位机图像处理和嵌入式模块部署(mcu之芯片选择)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 目前市面上的mcu很多&#xff0c;有国产的&#xff0c;有进口的&#xff0c;总之种类很多。以stm32为例&#xff0c;这里面又包括了stm32f1、stm32…

local dimming(局部调光)介绍

文章目录 1. 什么是local dimming2. 工作原理3. 类型4. 优点5. 缺点和局限7. 技术发展趋势 1. 什么是local dimming local dimming&#xff08;局部调光&#xff09;是电视和显示器中用于提升画面对比度和画质的背光技术。其基本原理是将背光源&#xff08;通常是LED&#xff…

python写接口性能测试

import time import requestsdef measure_response_time(api_url):try:start_time time.time()response requests.get(api_url, timeout10) # 设置超时时间为10秒end_time time.time()response_time end_time - start_timeprint(f"接口 {api_url} 的响应时间为&#…

UE5 OnlineSubsystem Steam创建会话失败解决方法

连接上Steam但是创建会话失败 解决方法 在DefaultEngine.ini中加上bInitServerOnClienttrue,这个其实在官方文档里用注释给出了&#xff0c;直接取消注释就行 删除项目目录中的Saved、Internmediate、Binaries目录 右键你的项目.uproject选择Generate Visual Studio project f…

QT 圆盘百分比

1. /* 设置抗锯齿 */painter.setRenderHints(QPainter::Antialiasing, true);/* 最外层的圆 */QRect drawRect event->rect();QRadialGradient gradient1(drawRect.center(), drawRect.width() / 2, drawRect.center()); gradient1.setColorAt(0, Qt::transparent); gradi…