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

LeetCode 917 仅仅反转字母 简单

题目 - 点击直达

  • 1. XXXXX
    • 1. 917 仅仅反转字母 简单
      • 1. 原题链接
      • 2. 题目要求
      • 3. 基础框架
    • 2. 解题思路
      • 1. 思路分析
      • 2. 时间复杂度
      • 3. 代码实现

1. XXXXX

1. 917 仅仅反转字母 简单

给你一个字符串 s ,根据下述规则反转字符串:

所有非英文字母保留在原有位置。
所有英文字母(小写或大写)位置反转。
返回反转后的 s 。

1. 原题链接

LeetCode 917 仅仅反转字母 简单

2. 题目要求

示例 1:

输入:s = “ab-cd”
输出:“dc-ba”
示例 2:

输入:s = “a-bC-dEf-ghIj”
输出:“j-Ih-gfE-dCba”
示例 3:

输入:s = “Test1ng-Leet=code-Q!”
输出:“Qedo1ct-eeLg=ntse-T!”

提示

1 <= s.length <= 100
s 仅由 ASCII 值在范围 [33, 122] 的字符组成
s 不含 ‘"’ 或 ‘\’

3. 基础框架

● Cpp代码框架

class Solution {
public:string reverseOnlyLetters(string s) {}
};

2. 解题思路

1. 思路分析

( 1 ) (1) (1) 只反转字符串中的字母,其他字符位置保持不变;
( 2 ) (2) (2) 利用快排思想,定义两个变量: l l l指向起始位置, r r r指向最后一个字符位置;
( 3 ) (3) (3) l l l向后查找直到找到第一个字母字符的位置, r r r向前查找直到找到第一个字母字符的位置;
注意 l l l r r r在查找过程中需要在有效范围,不在有效范围时则不进行查找查找;
( 4 ) (4) (4) l l l小于 r r r时,交换 l l l r r r位置上的字母字符,然后 l l l自减1, r r r自增1;
( 5 ) (5) (5) 重复 2 , 3 , 4 2,3,4 2,3,4步直到 l l l大于 r r r为止;

2. 时间复杂度

O ( N ) O(N) O(N)
l l l向后走, r r r向前走,直到二者相遇,共走了 n n n步;

3. 代码实现

class Solution {
public:string reverseOnlyLetters(string s) {int l = 0;int r = s.size() - 1;while(l < r){while(l < s.size() && !isalpha(s[l])){l++;}while(r >= 0 && !isalpha(s[r])){r--;}if(l < r){swap(s[l], s[r]);l++;r--;}}return s;}
};
http://www.lryc.cn/news/212546.html

相关文章:

  • JAVA深化篇_25—— IO流章节全网最全总结(附详细思维导图)
  • 易基因:ChIP-seq等揭示BRWD3调控KDM5活性以维持H3K4甲基化水平的表观机制|PNAS
  • C++深度优先(DFS)算法的应用:收集所有金币可获得的最大积分
  • uniapp中APP端使用echarts用formatter设置y轴保留2位小数点不生效
  • 无糖茶饮三十年,从无人问津到人手一瓶
  • 面向Three.js开发者的3D自动纹理化开发包
  • 数字孪生技术与VR:创造数字未来
  • 系统架构设计师-第15章-面向服务架构设计理论与实践-软考学习笔记
  • 为什么我觉得Rust比C++复杂得多?
  • python sqlalchemy(ORM)- 03 增删改查
  • Flutter笔记:完全基于Flutter绘图技术绘制一个精美的Dash图标(上)
  • 学习gorm:彻底弄懂Find、Take、First和Last函数的区别
  • 796. 子矩阵的和(二维前缀和)
  • 利用ChatGPT进行股票走势分析
  • 万字解析设计模式之单例模式
  • vue2.x 二次封装element ui 中的el-dialog
  • ssh连接Ubuntu虚拟机出现connection reset by ip地址 port 22怎么解决
  • 树莓派4B安装ffmpeg
  • LeetCode|动态规划|1035. 不相交的线 、53. 最大子数组和
  • 一体式IO模块:汽车行业的数字化转型助推器
  • OpenCV官方教程中文版 —— Hough 直线变换
  • 【Axure高保真原型】百分比堆叠柱状图
  • Vue.js中的双向数据绑定(two-way data binding)
  • TFN 2.5G SDH传输分析仪 FT100-D300S
  • 电脑录像功能在哪?一文帮你轻松破解
  • 基于长短期神经网络的可上调容量PUP预测,基于长短期神经网络的可下调容量PDO预测,LSTM可调容量预测
  • 站群服务器有哪些优势?
  • 故障诊断模型 | Maltab实现LSTM长短期记忆神经网络故障诊断
  • 【WSL 2】Windows10 安装 WSL 2,并配合 Windows Terminal 和 VSCode 使用
  • DbVisualizer和DBeaver启动不来,启动报错