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

无锡设计网站苏州seo优化

无锡设计网站,苏州seo优化,网站建设项目汇报,汕头网站建设前言 处理字符串主要是有思路,同时总结方法。 题目链接 151. 反转字符串中的单词 - 力扣(LeetCode) 55. 右旋字符串(第八期模拟笔试) 一、翻转字符串里的单词 这个题目的主要思路,代码采用从后往前遍历字…

前言

处理字符串主要是有思路,同时总结方法。

题目链接

 151. 反转字符串中的单词 - 力扣(LeetCode)

55. 右旋字符串(第八期模拟笔试)

一、翻转字符串里的单词

这个题目的主要思路,代码采用从后往前遍历字符串的方式,逐个提取单词并按反转顺序添加到新的字符串中,同时妥善处理了空格相关的问题,最终得到符合要求的输出字符串。

具体步骤:

  1. 初始化与循环准备:首先获取输入字符串 s 的长度,并将用于遍历字符串的索引 i 初始化为字符串最后一个字符的位置(i = s.size() - 1)。同时创建一个空字符串 ans,用来存储最终处理好的结果。

  2. 外层循环(处理每个单词):通过 while(i >= 0) 这个外层循环来依次处理字符串中的每个单词。从字符串末尾开始向前遍历,这个循环会持续执行,直到整个字符串都被处理完(也就是 i 小于 0 时结束)。

  3. 跳过末尾空格:在每次开始处理一个新的可能的单词前,有一个内层的 while 循环 while(i >= 0 && s[i] == ' ') --i;,它的作用是跳过字符串末尾连续出现的空格。比如字符串最后可能跟着多个空格,要先把这些空格跳过,找到真正最后一个单词的最后一个字符位置。

  4. 确定单词长度:紧接着另一个内层 while 循环 while(i >= 0 && s[i]!= ' ') --i, ++c;,这个循环从刚才跳过空格后的位置开始,继续向前遍历,只要当前字符不是空格(意味着还处于同一个单词内),就继续向前移动索引 i,同时用计数器 c 记录当前单词的字符个数。例如对于单词 "blue",这个循环会统计出它包含 4 个字符。

  5. 提取并添加单词到结果字符串:如果计数器 c 不为 0,说明找到了一个有效的单词,那么通过 s.substr(i + 1, c) 提取出这个单词(substr 函数用于截取从指定位置开始、指定长度的子字符串,这里 i + 1 是因为刚才循环结束时 i 指向单词的前一个位置,所以要加 1 才是单词开始的正确位置,c 就是单词的长度),并把这个单词添加到结果字符串 ans 中,同时在单词后面添加一个空格(ans += s.substr(i + 1, c) + " ";),方便后续区分不同单词。

  6. 去除最后多余的空格:当整个字符串都处理完后,通过 return ans.substr(0, ans.size() - 1); 返回最终结果。由于在添加每个单词时都额外添加了一个空格,最后结果字符串末尾会多一个空格,所以这里通过截取字符串去掉最后这个多余的空格,只返回前面正确处理好的内容,也就是完成了单词反转并且格式整理好的字符串。

string reverseWords(string s) {int i=s.size()-1;string ans;while(i>=0){int c=0;while(i>=0&&s[i]==' ')--i;while(i>=0&&s[i]!=' ')--i,++c;if(c)ans+=s.substr(i+1,c)+" ";}return ans.substr(0,ans.size()-1);}

二、右旋转字符串

 思路:先逆序翻转,然后再翻转前N个字符串,再翻转后面的。

//逆序翻转
#include<iostream>
#include<algorithm>
using namespace std;
int main() {int n;string s;cin >> n;cin >> s;int len = s.size(); //获取长度reverse(s.begin(), s.end()); // 整体反转reverse(s.begin(), s.begin() + n); // 先反转前一段,长度nreverse(s.begin() + n, s.end()); // 再反转后一段cout << s << endl;
} 

总结

对于字符串的处理,

遍历方式

正向遍历:按顺序从开头到结尾访问字符,适用于常规顺序处理。

反向遍历:从末尾往开头遍历,便于处理与结尾相关或需逆序操作的情况。

双指针遍历:两指针依规则同步或异步移动,用于对比、处理对应字符,如判断回文。

字符操作

比较:判断字符是否为特定类型,依结果执行不同逻辑。

转换:进行大小写、字符与数值等转换,便于后续处理。

替换与删除:按需对字符替换或删除。

子字符串处理

提取:截取子字符串用于进一步分析。

查找:判断是否包含特定子字符串。

辅助数据结构

:用于顺序反转、暂存符合后进先出特点的内容。

队列:按先进先出顺序处理相关元素。

哈希表:高效统计字符、子字符串出现情况等。

动态规划用于存在最优子结构性质的复杂问题,通过定义状态与状态转移方程求解最优解。

http://www.ds6.com.cn/news/29885.html

相关文章:

  • 网站想上线怎么做同城推广平台
  • c2c模式的特点有哪些成都网站优化
  • 做电影网站的服务器广州权威发布
  • 上海好的网站制作公司seopeixun
  • 日本真人做黄视频网站网站关键词优化怎么做的
  • 莘县网站建设公司深圳关键词快速排名
  • 做自己的网站网站推广方案范例
  • 一般在百度做网站多少钱域名申请的流程
  • 个人微信管理系统灰色行业关键词优化
  • 一个专门做试题的网站郴州网站建设
  • 网站建设的目的和目标google推广
  • 深圳永久免费网站建设哪个好百度风云榜小说榜排名
  • wordpress 头像地址潍坊seo外包平台
  • 网站免费做app百度收录批量提交入口
  • 遨游网站建设百度文库官网登录入口
  • 校园网站建设方案书搜狗推广登陆
  • 缙云网站建设沈阳百度seo排名优化软件
  • webstorm可以做网站吗域名注册服务网站哪个好
  • 高埗镇做网站沈阳市网站
  • 西安做网站公司哪家好自媒体135的网站是多少
  • 怎样上网站dns解析不了优化软件seo排名
  • 长沙网站排名方案网店推广运营策略
  • 合肥专业网站优化哪家好国外免费网站域名服务器查询软件
  • 建设厅八大员在哪个网站查询app推广软件
  • 如何自己做网站江西seo推广
  • 福田的网站建设公司福州seo按天付费
  • 网站设计制作新参考价格网络营销推广方法有哪些
  • 弹性盒子做微网站域名注册局
  • java做简易网站学做网站需要学什么
  • 网站开发工具简介外链怎么发