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

【541. 反转字符串 II 简单】

题目:

给定一个字符串 s 和一个整数 k,从字符串开头算起,每计数至 2k 个字符,就反转这 2k 字符中的前 k 个字符。

  • 如果剩余字符少于 k 个,则将剩余字符全部反转。
  • 如果剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符,其余字符保持原样。

示例 1:
输入:s = “abcdefg”, k = 2
输出:“bacdfeg”
示例 2:
输入:s = “abcd”, k = 2
输出:“bacd”

提示:
1 <= s.length <= 104
s 仅由小写英文组成
1 <= k <= 104


思路:

其实在遍历字符串的过程中,只要让 i += (2 * k),i 每次移动 2 * k 就可以了,然后判断是否需要有反转的区间。

因为要找的也就是每2 * k 区间的起点,这样写,程序会高效很多。

所以当需要固定规律一段一段去处理字符串的时候,要想想在在for循环的表达式上做做文章。
那么这里具体反转的逻辑我们要不要使用库函数呢,其实用不用都可以,使用reverse来实现反转也没毛病,毕竟不是解题关键部分。


代码:

class Solution {
public:string reverseStr(string s, int k) {for(int i = 0; i < s.length(); i += (2 * k)) {// 1.每隔 2k 个字符的前 k 个字符进行反转// 2.剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符if(i + k <= s.length()) {reverse(s.begin() + i, s.begin() + i + k);}else{// 3.剩余字符少于 k 个,则将剩余字符全部反转reverse(s.begin() + i, s.end());}}return s;}
};

总结:

时间复杂度: O(n)
空间复杂度: O(1)


参考:

代码随想录

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

相关文章:

  • 基于PHP的丽江旅游管理系统
  • vue3+Element-plus el-input 输入框组件二次封装(支持金额、整数、电话、小数、身份证、小数点位数控制,金额显示中文提示等功能)
  • jQuery 简介 ③ ready()事件函数、jQuery 二个原则及容错机制
  • 选择Alluxio来解决AI模型训练场景数据访问的五大理由
  • POS共识机制简介
  • Spring为什么要用三级缓存解决循环依赖?
  • 【Redis入门到精通三】Redis核心数据类型(List,Set)详解
  • 本科生如何学习机器学习
  • 海康威视摄像机和录像机的监控与回放
  • 校医务室健康服务系统小程序的设计
  • MySQL 中的 UTF-8 与 UTF8MB4:差异解析
  • nvm无法下载npm的问题
  • 数据结构与算法——Java实现 6.递归
  • .Net Core 生成管理员权限的应用程序
  • DAY15:链表实现学生信息管理系统
  • JAVA语法基础 day05-面向对象
  • 关于RabbitMQ重复消费的解决方案
  • 【SSM-Day2】第一个SpringBoot项目
  • 【PyTorch】张量操作与线性回归
  • 情感类智能体——你的微信女神
  • 基于SpringBoot+Vue+MySQL的养老院管理系统
  • 大数据Flink(一百二十二):阿里云Flink MySQL连接器介绍
  • FutureTask源码分析
  • Highcharts甘特图基本用法(highcharts-gantt.js)
  • 【Linux庖丁解牛】—Linux基本指令(上)!
  • node.js 中的进程和线程工作原理
  • Qt/C++ TCP调试助手V1.1 新增图像传输与接收功能(附发布版下载链接)
  • DNS解析流程
  • [PTA]7-1 藏头诗
  • 每日OJ题_牛客_WY22 Fibonacci数列(斐波那契)