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

网页游戏传奇单职业优化清理大师

网页游戏传奇单职业,优化清理大师,本地企业网站建设模板,百度推广销售题目: 给你一个字符串 s ,请你反转字符串中 单词 的顺序。 单词 是由非空格字符组成的字符串。s 中使用至少一个空格将字符串中的 单词 分隔开。 返回 单词 顺序颠倒且 单词 之间用单个空格连接的结果字符串。 注意:输入字符串 s中可能会…

题目:

给你一个字符串 s ,请你反转字符串中 单词 的顺序。

单词 是由非空格字符组成的字符串。s 中使用至少一个空格将字符串中的 单词 分隔开。

返回 单词 顺序颠倒且 单词 之间用单个空格连接的结果字符串。

注意:输入字符串 s中可能会存在前导空格、尾随空格或者单词间的多个空格。返回的结果字符串中,单词间应当仅用单个空格分隔,且不包含任何额外的空格。

示例 1:

输入:s = "the sky is blue"
输出:"blue is sky the"

示例 2:

输入:s = "  hello world  "
输出:"world hello"
解释:反转后的字符串中不能存在前导空格和尾随空格。

示例 3:

输入:s = "a good   example"
输出:"example good a"
解释:如果两个单词间有多余的空格,反转后的字符串需要将单词间的空格减少到仅有一个。

提示:

  • 1 <= s.length <= 104
  • s 包含英文大小写字母、数字和空格 ' '
  • s 中 至少存在一个 单词

代码:

class Solution {
public:void reverse(string& s, int start, int end){ //翻转,区间写法:左闭右闭 []for (int i = start, j = end; i < j; i++, j--) {swap(s[i], s[j]);}}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());}
}string reverseWords(string s) {removeExtraSpaces(s); //去除多余空格,保证单词之间之只有一个空格,且字符串首尾没空格。reverse(s, 0, s.size() - 1);int start = 0; //removeExtraSpaces后保证第一个单词的开始下标一定是0。for (int i = 0; i <= s.size(); ++i) {if (i == s.size() || s[i] == ' ') { //到达空格或者串尾,说明一个单词结束。进行翻转。reverse(s, start, i - 1); //翻转,注意是左闭右闭 []的翻转。start = i + 1; //更新下一个单词的开始下标start}}return s;}
};

分析:

一个erase本来就是O(n)的操作,erase操作上面还套了一个for循环,那么以上代码移除冗余空格的代码时间复杂度为O(n^2)。

那么使用双指针法来去移除空格,最后resize(重新设置)一下字符串的大小,就可以做到O(n)的时间复杂度。

改进代码:

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); // 重新设置字符串大小}
}

思考过程:先移除字符串前的空格,再移除中间的,再移除后面部分。

http://www.dtcms.com/wzjs/227395.html

相关文章:

  • 做网站 赚钱google中文搜索引擎入口
  • 手机网站制作教程下载百度一下你就知道下载
  • 镇江做网站seo如何查询网站收录情况
  • 做网站 小程序前景赣州seo优化
  • 网站管理员中心快速排名软件seo系统
  • 济南手机网站制作制定营销推广方案
  • 网站推广计划至少包括seo网络营销推广排名
  • 怎么做网站注册推广论坛推广怎么做
  • 网站免费优化上海关键词排名优化价格
  • 怎样在手机上面建设网站惠州疫情最新情况
  • 织梦手机端网站怎么做seo推广软件怎样
  • 网站开发需要用哪些东西头条权重查询
  • 广州17网站一起做网店网站搭建
  • 开发多语言网站网络视频营销平台
  • 淘宝u站怎么做网站的百度云资源链接分享群组
  • 淘宝找人做网站靠谱吗百度免费资源网站
  • 自动化网站建设pc优化工具
  • 做网站侵权成都网络营销品牌代理机构
  • 网站建建设公司和网络自建美国疫情最新数据消息
  • 武汉做网站及logo的公司合肥百度seo代理
  • 专业做化妆品外包材的招聘网站苏州网络推广seo服务
  • 网站多个页面要加引导aso100官网
  • 做网站需要网络服务器北京互联网营销公司
  • 网络科技公司排名aso应用商店优化
  • 回龙观网站建设2023年国家免费技能培训
  • wordpress资源站模板识图搜索在线 照片识别
  • 水资源监控能力建设 网站宁波关键词优化平台
  • 东莞网络营销外包公司合肥seo按天收费
  • 网站域名不备案网店推广实训系统
  • 个人网站设计及实现论文手机广告推广软件