《剑指offer》--字符串左旋

2024-02-15 13:12
文章标签 字符串 offer 左旋

本文主要是介绍《剑指offer》--字符串左旋,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

字符串左旋的三种方法

  • 1. 一个一个字符挪
  • 2. 库函数---strcpy和strncat
  • 3. 三段逆置法

在这里插入图片描述

1. 一个一个字符挪

代码实现如下:

#include <stdio.h>
#include <string.h>void Left_Reverse(char* str,int k)
{int len = strlen(str);//6int time = 0;time = k % len;//真正要旋转的次数int i = 0;for (i = 0; i < time; i++){int j = 0;char tmp = str[0];for (j = 0; j < len - 1; j++){str[j] = str[j + 1];}str[j] = tmp;}
}int main()
{char str[30] = "abcdef";int k = 3;//要旋转几个字符Left_Reverse(str,k);printf("%s\n", str);return 0;
}

画图说明:
在这里插入图片描述
这是循环执行一次的过程。上述代码中还要注意的是time=k%len.例如当k=7时,我们要旋转7次,但是当旋转第6次时字符串变回原样了,这就相当于还需旋转一次即可,k%len=1。

2. 库函数—strcpy和strncat

代码实现如下:

#include <stdio.h>
#include <string.h>int main()
{char str[30] = "abcdef";int k = 2;int len = strlen(str);int time = k % len;char tmp[256] = { 0 };//把cdef拷贝进tmp数组中strcpy(tmp, str + time);//把str中的前两个字符追加到tmp中,此时tmp中是cdefabstrncat(tmp, str, time);//最后把tmp拷贝回str中strcpy(str, tmp);printf("%s\n", str);return 0;
}

画图演示:

在这里插入图片描述

这种方法是比较简便的,我们要了解strcpy和strncat函数的使用。

3. 三段逆置法

代码实现如下:

#include <stdio.h>
#include <string.h>//实现字符串左右端字符的交换
void Reverse(char* str, int left, int right)
{while (left < right){char tmp =str[left];str[left] = str[right];str[right] = tmp;left++;right--;}
}void Left_Round(char* str, int k)
{int len = strlen(str);int time = k % len;//三段逆置Reverse(str, 0,time - 1);Reverse(str, time,len-1);Reverse(str, 0,len - 1);}int main()
{char str[30] = "abcdef";int k = 3;Left_Round(str, k);printf("%s\n", str);return 0;
}

画图演示:
在这里插入图片描述
这里我们需要注意,我们定义的left和right是下标,在Reverse函数中我们也是对str的下标进行操作。

这篇关于《剑指offer》--字符串左旋的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/711485

相关文章

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

Java字符串处理全解析(String、StringBuilder与StringBuffer)

《Java字符串处理全解析(String、StringBuilder与StringBuffer)》:本文主要介绍Java字符串处理全解析(String、StringBuilder与StringBu... 目录Java字符串处理全解析:String、StringBuilder与StringBuffer一、St

MySQL更新某个字段拼接固定字符串的实现

《MySQL更新某个字段拼接固定字符串的实现》在MySQL中,我们经常需要对数据库中的某个字段进行更新操作,本文就来介绍一下MySQL更新某个字段拼接固定字符串的实现,感兴趣的可以了解一下... 目录1. 查看字段当前值2. 更新字段拼接固定字符串3. 验证更新结果mysql更新某个字段拼接固定字符串 -

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

golang获取当前时间、时间戳和时间字符串及它们之间的相互转换方法

《golang获取当前时间、时间戳和时间字符串及它们之间的相互转换方法》:本文主要介绍golang获取当前时间、时间戳和时间字符串及它们之间的相互转换,本文通过实例代码给大家介绍的非常详细,感兴趣... 目录1、获取当前时间2、获取当前时间戳3、获取当前时间的字符串格式4、它们之间的相互转化上篇文章给大家介

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

python中字符串拼接的几种方法及优缺点对比详解

《python中字符串拼接的几种方法及优缺点对比详解》在Python中,字符串拼接是常见的操作,Python提供了多种方法来拼接字符串,每种方法有其优缺点和适用场景,以下是几种常见的字符串拼接方法,需... 目录1. 使用 + 运算符示例:优缺点:2. 使用&nbsjsp;join() 方法示例:优缺点:3

java字符串数字补齐位数详解

《java字符串数字补齐位数详解》:本文主要介绍java字符串数字补齐位数,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java字符串数字补齐位数一、使用String.format()方法二、Apache Commons Lang库方法三、Java 11+的St

C++字符串提取和分割的多种方法

《C++字符串提取和分割的多种方法》在C++编程中,字符串处理是一个常见的任务,尤其是在需要从字符串中提取特定数据时,本文将详细探讨如何使用C++标准库中的工具来提取和分割字符串,并分析不同方法的适用... 目录1. 字符串提取的基本方法1.1 使用 std::istringstream 和 >> 操作符示