笔试题1 -- 吃掉字符串中相邻的相同字符(点击消除_牛客网)

吃掉字符串中相邻的相同字符

文章目录

  • 吃掉字符串中相邻的相同字符
    • 题目重现
    • 解法一:(基于 erase() 函数实现)
    • 解法二:(利用 栈 辅助实现)
    • 总结

题目链接: 点击消除_牛客网

题目重现

牛牛拿到了一个字符串。
他每次“点击”,可以把字符串中相邻两个相同字母消除,例如,字符串 “abbc” 点击后可以生成 “ac”。
但相同而不相邻、不相同的相邻字母都是不可以被消除的。
牛牛想把字符串变得尽可能短。他想知道,当他点击了足够多次之后,字符串的最终形态是什么?

输入描述

一个字符串,仅由小写字母组成。(字符串长度不大于300000)

输出描述

一个字符串,为“点击消除”后的最终形态。若最终的字符串为空串,则输出0。

解法一:(基于 erase() 函数实现)

缺点:

  • 效率问题:使用 erase() 函数会导致字符串中的元素频繁移动,特别是在字符串较长时,这会造成较大的性能开销。
  • 复杂的边界处理:代码中需要多次检查迭代器是否到达字符串的末尾,这增加了代码的复杂性。

代码示例:

void eatCharacters(std::string& s)
{auto cur = s.begin();auto pre = cur + 1;for (; pre != s.end(); pre++, cur++){while (*cur == *pre){bool cur_is_begin = (cur == s.begin()) ? true : false;auto cur_l = cur - 1;pre = s.erase(cur, pre + 1);if (pre == s.end()) { return; }		// 注意这里判断避免后面越界if (cur_is_begin){cur = pre;pre++;if (pre == s.end()) { return; }		// 注意这里判断避免后面越界}else{cur = cur_l;}}}
}void test() {std::string input;std::cin >> input; // 从标准输入读取字符串eatCharacters(input);if (input.size() == 0){cout << 0 << endl;}else{std::cout << input << std::endl; // 输出最终状态}
}

提交截图:

在这里插入图片描述

评价:

时间复杂度:

  • 最坏情况下,每次 erase() 调用都可能导致整个字符串的复制,因此时间复杂度为 O(n^2),其中 n 是字符串的长度。

空间复杂度:

  • 由于直接在原字符串上操作,空间复杂度为 O(1)

实际运行时间:

  • 在字符串较短或者需要消除的字符对较少时,这种方法可能表现得相当快。
  • 在字符串较长且有大量相邻字符对需要消除时,性能会显著下降。

适用场景:

  • 当处理的字符串较短,且内存资源受限时,这种方法可能更合适。

解法二:(利用 栈 辅助实现)

缺点:

  • 空间复杂度:虽然时间复杂度有所优化,但是这种方法需要额外的空间来存储栈。

代码示例:

void eatCharacters(std::string& s) {stack<char> st;for (auto e : s){if (st.empty() || st.top() != e) { st.push(e); }else {st.pop();}}s.clear();while (!st.empty()){s = st.top() + s;st.pop();}
}void test() {std::string input;std::cin >> input; // 从标准输入读取字符串eatCharacters(input);if (input.size() == 0){cout << 0 << endl;}else{std::cout << input << std::endl; // 输出最终状态}}

提交截图:

在这里插入图片描述

评价:

时间复杂度:

  • 由于每个字符只被处理一次,时间复杂度为 O(n)

空间复杂度:

  • 需要一个额外的栈来存储字符,最坏情况下空间复杂度为 O(n)

实际运行时间:

  • 对于任何长度的字符串,这种方法都能保持稳定的性能。
  • 在处理大量数据时,这种方法的性能优势更加明显。

适用场景:

  • 当处理的字符串非常长,或者需要频繁执行消除操作时,这种方法更为高效。

总结

​ 在选择解法时,应考虑问题的规模和性能要求。对于小规模数据,两种方法都可以工作得很好,但解法一可能更节省内存。对于大规模数据,解法二的性能优势将非常明显,尽管它需要更多的内存。在实际应用中,如果内存不是问题,推荐使用解法二,因为它提供了更好的时间效率和代码的可维护性。
执行消除操作时,这种方法更为高效。

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

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

相关文章

关联规则挖掘(一)

目录 一、关联规则的概念&#xff08;一&#xff09;基本概念&#xff08;二&#xff09;项集的性质 二、关联规则的Apriori算法&#xff08;一&#xff09;发现频繁项集&#xff08;二&#xff09;产生关联规则 一、关联规则的概念 &#xff08;一&#xff09;基本概念 事务数…

byobu

byobu 终端多路复用器 一、byobu 安装二、byobu 使用三、其他终端多路复用器四、ssh byobu 远程协作 系统环境: linux(ubuntu,debian,kali) 一、byobu 安装 byobu 是包装过的tmux #sudo apt install tmux sudo apt install byobubyobu二、byobu 使用 创建窗口: Ctrl a c…

windows编译xlnt,获取Excel表里的数据

用git拉取项目 这个文件是空的 要用git拉下来&#xff0c;使用终端编译xlnt库 点击解决方案 运行生成 然后新建项目&#xff0c;配置好库&#xff0c; #include <iostream> #include <xlnt/xlnt.hpp>int main() {// 打开 Excel 文件xlnt::workbook workbook;workb…

Redis从入门到精通(十九)多级缓存(四)Nginx共享字典实现本地缓存

文章目录 前言6.5 实现多级缓存6.5.6 Nginx本地缓存6.5.6.1 代码实现6.5.6.2 功能测试 6.6 缓存同步6.6.1 缓存同步策略6.6.2 异步通知策略 前言 Redis多级缓存系列文章&#xff1a; Redis从入门到精通(十六)多级缓存(一)Caffeine、JVM进程缓存 Redis从入门到精通(十七)多级缓…

EPSON两款新的加速器M-A552AC1和M-A552AR1

老化的社会基础设施以及基础设施维护、监控和更新成本的飙升被认为是国家和社区面临的严重社会问题&#xff0c;在有着高度城市化的国家尤为明显。在这样的环境和认识推动下,利用传感器监测结构健康的技术需求的日益增长。爱普生推出了两款新的高性能加速器M-A552AC1和M-A552AR…

【C++】开始使用stack 与 queue

送给大家一句话&#xff1a; 忍受现实给予我们的苦难和幸福&#xff0c;无聊和平庸。 – 余华 《活着》 开始使用queue 与 stack 1 前言2 stack与queue2.1 stack 栈2.2 queue 队列2.3 使用手册 3 开始使用Leetcode 155.最小栈牛客 JZ31 栈的弹出压入序列Leetcode 150.逆波兰表达…

tailwindcss在manoca在线编辑智能感知

推荐一下monaco-tailwindcss库&#xff0c;它实现在monaco-editor网页在线编辑器中对tailwindcss的智能感知提示&#xff0c;在利用tailwindcss实现html效果布局。非常的方便。 生成CSS

freertos作业day1

1.总结keil5下载代码和编译代码需要注意的事项 1.&#xff09;仿真器设置&#xff1a; 点击魔术棒&#xff0c;选择debug选项&#xff0c;找到使用的仿真器&#xff0c;选择ST-LINK仿真器&#xff0c;点击setting&#xff0c;选择flash download ,勾选reset and run,选择pack…

基于zookeeper安装Kafka集群

操作系统&#xff1a;centOS 9 Stream&#xff0c;6台&#xff0c;基于vmware虚拟机创建 准备工作 确认系统环境&#xff1a; 确保所有服务器已安装了最新更新。安装Java Development Kit (JDK) 8或更高版本&#xff0c;因为ZooKeeper和Kafka都是基于Java开发的。例如&#x…

PaddleOCR训练自己模型(2)----参数配置及训练

一、介绍 paddleocr分为文字定位(Det)和文字识别(Rec)两个部分 二、定位模型训练 &#xff08;1&#xff09;Det预训练模型下载&#xff1a;https://paddleocr.bj.bcebos.com/PP-OCRv4/chinese/ch_PP-OCRv4_det_train.tar &#xff08;2&#xff09;下载完之后&#xff0c;…

案例研究|众乐邦将MeterSphere持续测试平台融入DevOps流水线

众乐邦网络科技有限公司&#xff08;以下简称为“众乐邦”&#xff09;是一家企业服务公司。其旗下的众乐邦灵活用工数字化薪税管理平台&#xff08;以下简称为灵活用工管理平台&#xff09;&#xff0c;以财税服务视角切入灵活用工场景&#xff0c;连接企业、灵活就业者和监管…

家居网购项目(手写分页)

文章目录 1.后台管理—分页显示1.程序框架图2.编写数据模型Page.java 3.编写dao层1.修改FurnDao增加方法 2.修改FurnDaoImpl增加方法 3.单元测试FurnDaoTest 4.编写service层1.修改FurnService增加方法 2.修改FurnServiceImpl增加方法3.单元测试FurnServiceTest 5.编写DataUtil…