【算法与数据结构】剑指 Offer 58 - II. LeetCode左旋转字符串

news2025/1/11 11:11:01

文章目录

  • 一、题目
  • 二、解法
  • 三、完整代码

所有的LeetCode题解索引,可以看这篇文章——【算法和数据结构】LeetCode题解。

一、题目

在这里插入图片描述

二、解法

  思路分析:以例一为例,例一的字符串可以分为"ab" "cdefg"两个子串,首先翻转整个字符串,然后翻转左旋的子字符串。实现了不用额外空间的算法。很简单的代码不解释了。
  程序如下

class Solution {
public:
	void my_swap(string& s, int start, int end) {
		for (int i = start, j = end; i < j; ++i, --j) {
			s[i] ^= s[j];	// ^位运算当中的异或算子
			s[j] ^= s[i];
			s[i] ^= s[j];
			// swap(s[i],s[j]);	// 调用库函数 
		}
	}
	string reverseLeftWords(string s, int n) {
		// 翻转字符串
		my_swap(s, 0, s.size() - 1);
		// 翻转子串
		my_swap(s, 0, s.size() - n - 1);
		my_swap(s, s.size() - n, s.size() - 1);
		return s;
	}
};

复杂度分析:

  • 时间复杂度: O ( n ) O(n) O(n),实际上,翻转字符串用了 O ( n ) O(n) O(n),翻转子串用了 O ( n ) O(n) O(n),一共是 O ( 2 n ) = O ( n ) O(2n)=O(n) O(2n)=O(n)
  • 空间复杂度: O ( 1 ) O(1) O(1),没有用到额外空间。

三、完整代码

# include <iostream>
# include <string>
using namespace std;

class Solution {
public:
	void my_swap(string& s, int start, int end) {
		for (int i = start, j = end; i < j; ++i, --j) {
			s[i] ^= s[j];	// ^位运算当中的异或算子
			s[j] ^= s[i];
			s[i] ^= s[j];
			// swap(s[i],s[j]);	// 调用库函数 
		}
	}
	string reverseLeftWords(string s, int n) {
		// 翻转字符串
		my_swap(s, 0, s.size() - 1);
		// 翻转子串
		my_swap(s, 0, s.size() - n - 1);
		my_swap(s, s.size() - n, s.size() - 1);
		return s;
	}
};

int main()
{
	string s = "abcdefg";
	int k = 2;
	Solution s1;
	cout << "目标字符串:\n" << "“" << s << "”" << endl;
	string str = s1.reverseLeftWords(s, k);
	cout << "翻转后的字符数组:\n" << "“" << str << "”" << endl;
	system("pause");
	return 0;
}

end

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/716021.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

element Plus Select选择器实现查询搜索 下拉选择

这Select选择器用于哪里 怎么用&#xff1f; Select 选择器可以用于许多不同的场景&#xff0c;包括但不限于以下几个方面&#xff1a; 表单&#xff1a;Select 选择器常用于表单中的下拉选择字段&#xff0c;例如选择国家、城市、性别、职位等。用户可以从预定义的选项中选择…

软考:中级软件设计师:计算机体系结构,CISC和RISC,Flynn分类,指令流水线,吞吐率,效率

软考&#xff1a;中级软件设计师:计算机体系结构 提示&#xff1a;系列被面试官问的问题&#xff0c;我自己当时不会&#xff0c;所以下来自己复盘一下&#xff0c;认真学习和总结&#xff0c;以应对未来更多的可能性 关于互联网大厂的笔试面试&#xff0c;都是需要细心准备的…

Win10任务栏的天气怎么关闭?Win10任务栏的天气关闭方法

Win10任务栏的天气怎么关闭&#xff1f;Win10任务栏的天气功能可以提供即时的天气信息&#xff0c;方便用户随时获取当前和未来的天气预报。然而&#xff0c;对于一些用户来说&#xff0c;这个天气小部件可能并不是必需的&#xff0c;并且想要关闭它以腾出任务栏的空间。无论是…

工程师抓秃头总结卡尔曼滤波简单原理及收敛原因

1、关于矩阵的一些想法 有小伙伴看到矩阵就脑瓜壳疼&#xff0c;那是没有了解数学家为啥闲的没事要用矩阵呢&#xff0c;从来没有人说不用矩阵就算不了&#xff0c;矩阵最初我认为是数学家偷懒&#xff0c;因为写一堆方程字太多太长&#xff0c;所以用了简写的形式&#xff0c;…

【SAP-MDG】售前常见问题

在与甲方的交流过程中&#xff0c;常常会有以下几个问题 一、“为什么要上主数据管理系统&#xff1f;” 见&#xff1a;主数据管理的意义 二、“有了主数据管理机制&#xff0c;还要不要上主数据管理平台&#xff1f;” 主数据的管理机制是通用性的&#xff0c;我们在任何系…

【算法与数据结构】28、LeetCode实现strStr函数

文章目录 一、题目二、暴力穷解法三、KMP算法四、Sunday算法五、完整代码 所有的LeetCode题解索引&#xff0c;可以看这篇文章——【算法和数据结构】LeetCode题解。 一、题目 二、暴力穷解法 思路分析&#xff1a;首先判断字符串是否合法&#xff0c;然后利用for循环&#xff…

:hover悬浮在元素上方时,不出现黑边

给element plus的下拉菜单设置悬浮样式 .el-dropdown :hover{border: none;outline: none; } border:node 表示元素本身的边框没有了 outline:none 表示元素的轮廓线没有了

K8S集群管理

集群管理 1 集群管理1.1 节点管理1.1.1 令牌管理1.1.2 集群扩缩容1.1.3 集群升级1.1.4 证书管理 1.2 数据管理1.2.1 ETCD基础1.2.2 ETCD实践1.2.3 备份还原1.2.4 ETCD集群 1 集群管理 1.1 节点管理 1.1.1 令牌管理 学习目标 这一节&#xff0c;我们从 令牌基础、令牌实践、…

【Part 2】博物馆防刷票小程序接入无感验证--跳转式接入

前文在这里&#xff1a; 【Part 1】现在去博物馆都预约不上了&#xff0c;黑产多少有点疯狂了 前面这篇文章讲到目前博物馆的门票基本被黄牛薅没了&#xff0c;我们普通人只能通过黄牛去买票&#xff0c;并且讲到了预约小程序如何通过插件式接入无感验证。 这篇文章我们继续讲…

数据结构之 时间复杂度与空间复杂度

目录 1&#xff1a;什么是时间复杂度和空间复杂度 2&#xff1a;时间复杂度与空间复杂度求法 3&#xff1a;几个典型时间复杂度与空间复杂度的分析 1&#xff1a;什么是时间复杂度与空间复杂度 首先对于我们所写的程序来说&#xff0c;为了评估一个算法的好与坏我们需要通过…

用*打印一个空心三角形

通过找规律发现&#xff0c;有*的位置坐标是&#xff08;0&#xff0c;3&#xff09;&#xff08;1&#xff0c;2&#xff09;&#xff08;1&#xff0c;4&#xff09;&#xff08;2&#xff0c;1&#xff09;&#xff08;2&#xff0c;5&#xff09;&#xff0c;三角形左边坐标…

Python爬虫使用代理IP的实现

使用爬虫时&#xff0c;如果目标网站对访问的速度或次数要求较高&#xff0c;那么你的 IP 就很容易被封掉&#xff0c;也就意味着在一段时间内无法再进行下一步的工作。这时候代理 IP 能够给我们带来很大的便利&#xff0c;不管网站怎么封&#xff0c;只要能找到一个新的代理 I…

软考:中级软件设计师:计算机存储结构,cache,局部性原理,RAM和ROM,磁盘结构和计算

软考&#xff1a;中级软件设计师:计算机存储结构 提示&#xff1a;系列被面试官问的问题&#xff0c;我自己当时不会&#xff0c;所以下来自己复盘一下&#xff0c;认真学习和总结&#xff0c;以应对未来更多的可能性 关于互联网大厂的笔试面试&#xff0c;都是需要细心准备的…

2023年铁矿石行业研究报告

第一章 行业概况 铁矿石行业是指从地壳中开采铁矿石&#xff0c;经过破碎、筛选、洗选等步骤&#xff0c;使其达到工业上可用的标准的一整套产业。这个行业涵盖了从开采到运输&#xff0c;再到冶炼和销售的全过程。它是全球制造业&#xff0c;尤其是钢铁工业的基础。 铁矿石的…

org.apache.commons(commons-csv)下载CSV增加BOM头

网络说明 代码说明 依赖 <!--https://mvnrepository.com/artifact/org.apache.commons/commons-csv--><dependency><groupId>org.apache.commons</groupId><artifactId>commons-csv</artifactId><version>1.8</version><…

C++学习笔记-第9单元 异常处理

第9单元 异常处理 文章目录 第9单元 异常处理单元导读9.1 异常处理概览9.1.1 异常处理概览9.1.2 异常处理机制的优点 9.2 异常匹配与内建异常类9.2.1 异常匹配与异常类9.2.2 内建异常类 9.3 自定义异常类与多重捕获9.3.1 自定义异常类9.3.2 捕获多种无关异常9.3.3 捕获派生异常…

C#Winform 中tabcontrol 美化实例

本篇讲解tabcontrol 美化实例,我们项目开发中为了保持项目界面的风格的一致性,需要美化tabcontrol控件,系统自带的控件样式不能更改,无法满足需求。 先看效果 实现过程 创建winform项目,添加组件类控件 修改名称,点击添加 cs代码 using System.Drawing; using Sys…

TX Text Control .NET for WPF 31.SP3 Crack

.NET WPF 应用程序的文档处理 将文档编辑、创建和 PDF 生成添加到您的 WPF 应用程序中。 视窗用户界面 功能齐全的文档编辑器 TX Text Control 是一款免版税、完全可编程的丰富编辑控件&#xff0c;它在专为 Visual Studio 设计的可重用组件中为开发人员提供了广泛的文字处理功…

Spring Native 实现 0.059s 启动一个SpringBoot项目!

前言 最近自己用Spring Cloud Alibaba做了一个微服务架构的项目&#xff0c;部署的时候遇到了难题&#xff1a;内存不够。目前该项目有7个微服务&#xff0c;因为我只有一台阿里云的服务器(2C 4G)&#xff0c;所以我只能把所有的微服务部署在一台服务器上&#xff0c;部署方式…

uni-App踩坑记录

​ 1、uni自己封装的axios在真机中失效&#xff0c;发不出请求 uniapp中使用axios 需要配置适配器 (添加适配器有点费劲&#xff0c;直接封装uni自带请求也可以) axios-adapter-uniapp传送门 axios.defaults.adapter function(config) { //自己定义个适配器&#xff0c;用来…