当前位置: 首页 > news >正文

leetcode刷题笔记/代码随想录笔记——移除字符串中多余空格

1. 使用erase()函数

void removeExtraSpaces(string& s) {for (int i = s.size() - 1; i > 0; i--) {if (s[i] == s[i - 1] && s[i] == ' ') {s.erase(s.begin() + i);}}// 删除字符串最后面的空格if (s.size() > 0 && s[s.size() - 1] == ' ') {s.erase(s.begin() + s.size() - 1);}// 删除字符串最前面的空格if (s.size() > 0 && s[0] == ' ') {s.erase(s.begin());}
}

时间复杂度:O(n^2)

2. 双指针移除空格,resize()字符串大小

//版本一 
void removeExtraSpaces(string& s) {int slowIndex = 0, fastIndex = 0; // 定义快指针,慢指针// 去掉字符串前面的空格while (s.size() > 0 && fastIndex < s.size() && s[fastIndex] == ' ') {fastIndex++;}for (; fastIndex < s.size(); fastIndex++) {// 去掉字符串中间部分的冗余空格if (fastIndex - 1 > 0&& s[fastIndex - 1] == s[fastIndex]&& s[fastIndex] == ' ') {continue;} else {s[slowIndex++] = s[fastIndex];}}if (slowIndex - 1 > 0 && s[slowIndex - 1] == ' ') { // 去掉字符串末尾的空格s.resize(slowIndex - 1);} else {s.resize(slowIndex); // 重新设置字符串大小}
}
    void removeExtraSpaces(string& s){int left=0,right=0;//去除字符串前空格while(right<s.size()&&s[right]==' ') right++;while(right<s.size()){if(s[right]==' '&&s[right]==s[right-1]) right++;else s[left++]=s[right++]; }if(s[left-1]==' ') s.resize(left-1);else s.resize(left);}

时间复杂度:O(n)

3. 双指针移除空格,resize()字符串大小优化版

// 版本二 
void removeExtraSpaces(string& s) {//去除所有空格并在相邻单词之间添加空格, 快慢指针。int slow = 0;   //整体思想参考https://programmercarl.com/0027.移除元素.htmlfor (int i = 0; i < s.size(); ++i) { //if (s[i] != ' ') { //遇到非空格就处理,即删除所有空格。if (slow != 0) s[slow++] = ' '; //手动控制空格,给单词之间添加空格。slow != 0说明不是第一个单词,需要在单词前添加空格。while (i < s.size() && s[i] != ' ') { //补上该单词,遇到空格说明单词结束。s[slow++] = s[i++];}}}s.resize(slow); //slow的大小即为去除多余空格后的大小。
}
    void removeExtraSpaces(string& s){int left=0,right=0;for(;right<s.size();right++){//仅处理s[right]不为空格的情况if(s[right]==' ') continue;if(left!=0) s[left++]=' ';//注意while循环中要限制right<s.size()while(right<s.size()&&s[right]!=' '){s[left++]=s[right++];}}s.resize(left);}

时间复杂度:O(n)

http://www.lryc.cn/news/177641.html

相关文章:

  • dataGrip导出导入的方式
  • LeetCode279. 完全平方数
  • 【CMake】add_dependencies 命令
  • go语言unsafe.Pointer与uintptr
  • ddos打到高防cdn上会发生什么
  • 【单调栈】503. 下一个更大元素 II
  • C++ decltype类型
  • 【题解】JZOJ3854 分组
  • 区块链实验室(26) - 区块链期刊Blockchain: Research and Applications
  • 【学习笔记】[ARC153F] Tri-Colored Paths
  • 基于SSM的实习管理系统
  • 在Vue中通过ElementUI构建前端页面【登录,注册】,在IEDA构建后端实现前后端分离
  • TX2 open ttyTHS2
  • conan入门(二十八):解决conan 1.60.0下 arch64-linux-gnu交叉编译openssl/3.1.2报错问题
  • Xcode 15 运行<iOS 14, 启动崩溃问题
  • HTTPS协议概述
  • jmeterbeanshell调用jsonpath获取对应值
  • C++中实现雪花算法来在秒级以及毫秒及时间内生成唯一id
  • OPTEE Gprof(GNU profile)
  • MySQL 事务的操作指南(事务篇 二)
  • Oracle 查询 SQL 语句
  • gin 基本使用
  • 8月最新修正版风车IM即时聊天通讯源码+搭建教程
  • NSDT孪生场景编辑器系统介绍
  • 3D WEB轻量化引擎HOOPS助力3D测量应用蓬勃发展:效率、精度显著提升
  • 【Orange Pi】Orange Pi5 Plus 安装记录
  • NLP 项目:维基百科文章爬虫和分类 - 语料库阅读器
  • 查看吾托帮88.47的docker里的tomcat日志
  • 衷心 祝愿
  • 表单中某一项点击添加和删除