力扣旋转字符串

news2024/11/18 5:35:29

在这里插入图片描述

🎈个人主页:🎈 :✨✨✨初阶牛✨✨✨
🐻推荐专栏: 🍔🍟🌯 c语言初阶
🔑个人信条: 🌵知行合一
🍉本篇简介:>:介绍字符串旋转,左旋,右旋即旋转结果.
金句分享:
✨好好干,日子会越来越甜。✨

目录

  • 一、轮转数组
    • 方法一:暴力解题:
    • 方法二:三步翻转法.
  • 二.左旋转字符串
  • 三:字符串旋转结果
    • 思路一:
    • 思路2:

一、轮转数组

题目链接:(来源于力扣)(右旋)
给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。
示例 1:

输入: nums = [1,2,3,4,5,6,7], k = 3
输出: [5,6,7,1,2,3,4]
解释:
向右轮转 1 步: [7,1,2,3,4,5,6]
向右轮转 2 步: [6,7,1,2,3,4,5]
向右轮转 3 步: [5,6,7,1,2,3,4]

方法一:暴力解题:

一位一位的移动,用循环完成移动一位的操作,一次交换相邻两个数.
例如:右移一位
数据:1 2 3 4 5 6 7
图解:

		右移一位过程图:
//右移一位操作
	for (i = numsSize - 1; i > 0; i--)
		{
			int tmp = nums[i];
			nums[i] = nums[i - 1];
			nums[i - 1] = tmp;
		}

右移k位(外层加一个k次循环)
注意:如果移动的位数是数字个数的整数倍数,则相当于没有移动,用k%numsSize可以避免没有必要的多余循环.

void rotate(int* nums, int  numsSize, int k)//外层循环
{
	int i = 0;
	k = k % numsSize;
	while (k--)
	{
		for (i = numsSize - 1; i > 0; i--)//内部循环
		{
		//交换
			int tmp = nums[i];
			nums[i] = nums[i - 1];
			nums[i - 1] = tmp;
		}
	}
}

小改进:
将内部的每次循环都要创建变量进行交换,改成直接覆盖,将最后一位数字拷贝一份后,将前面的数据直接向后面覆盖,最后将首位数据赋值为拷贝的最后一位数值也可以完成操作.

图解:

代码:

void rotate(int* nums, int numsSize, int k) {
	int i = 0;
	k = k % numsSize;
	
	while (k--)
	{
		int tmp = nums[numsSize - 1];//最后一位数字拷贝一份
		for (i = numsSize - 1; i > 0; i--)//内部循环
		{
			nums[i] = nums[i - 1];//前面的数据直接向后面覆盖
		}
		nums[0] = tmp;//首位数据赋值为拷贝的最后一位数
	}
	
}

但是,暴力解决,在面对大量的数据时,运行速度会慢很多,

方法二:三步翻转法.

其实有一个很神奇的现象,当我们需要右轮转 k 个位置时,可以将这个整形数组看作两部分
前半部分是:前n-k个数据,下标为[0,numsSize - k-1]
后半部分是:最后的k个数据,下标为:[numsSize - k,numsSize - 1]
然后分别逆序两部分,最后整体逆序就行了.
例如:数据1 2 3 4 5 6 7
逆序前半部分:4 3 2 1 5 6 7
逆序后半部分:4 3 2 1 7 6 5
逆序全部: 7 6 5 1 2 3 4

void reverse(int *arr,int left,int right)
{
	while(left<right)
	{
		int tmp = arr[left];
		arr[left] = arr[right];
		arr[right] = tmp;
		left++;
		right--;
	}
}
void rotate(int* nums, int numsSize, int k){
    	if(numsSize==0)
	{
		return nums;
	}
    k = k % numsSize;
    reverse(nums, 0, numsSize - k-1);//逆序前半部分
	reverse(nums, numsSize - k, numsSize - 1);//逆序后半部分
	reverse(nums, 0, numsSize - 1);//逆序整体
}

二.左旋转字符串

传送门:
题目描述:
一个给定的字符序列 S ,请你把其循环左移 K 位后的序列输出
示例1:

输入:
“abcXYZdef”,3

返回值:
“XYZdefabc”

学完上面的数组右旋,相信左旋字符串应该可以照猫画虎吧!

同理使用:三步翻转法

 #include <string.h>
void reverse(char *arr,int left,int right)
{
	
	while(left<right)
	{
		char tmp = arr[left];
		arr[left] = arr[right];
		arr[right] = tmp;
		left++;
		right--;
	}
}
char* LeftRotateString(char* nums, int k ) {
	int sz=strlen(nums);
	if(sz==0)
	{
		return nums;
	}
	k = k % sz;
	reverse(nums, 0, k-1);
	reverse(nums, k, sz - 1);
	reverse(nums, 0, sz - 1);
	return nums;
}

三:字符串旋转结果

题目描述:
自定义一个函数,要求判断一个字符串是否为另外一个字符串旋转之后的字符串。
要求这两个字符串长度相等.
返回值:
是: 返回1
不是:返回0.

示例1:

给定字符串s1 =AABCD和字符串s2 = BCDAA
s1左旋2个数后可以得到s2,所以结果为真,返回1;

示例2:

给定s1=abcd和s2=ACBD,
s1无法通过旋转得到,s2.结果为假,返回0;

思路一:

通过计算字符串长度得到sz,然后循环旋转sz次,每次旋转后与s2进行比较.

#include <stdio.h>
#include <string.h>
#include <assert.h>
void reversed(char* left,char* right)
{
	assert(left);//防止传入空指针
	assert(right);
	while (left < right)
	{
		char tmp = *left;
		*left = *right;
		*right = tmp;
		left++;
		right--;
	}
}
void left_revolve(char*arr,int k)
{
	int sz = strlen(arr);
	k %= sz;
		//逆序前k个
		reversed(arr, arr+k-1);
		//逆序后面剩下的
		reversed(arr+k, arr+sz-1);
		//逆序整体
		reversed(arr, arr + sz - 1);
}
int is_revolve(char* s1, char* s2, int sz)
{
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		left_revolve(s1, 1);
		if (strcmp(s1, s2) == 0)
		{	
			return 1;
		}
	}
	return 0;
}
int main()
{
	char s1[50] = { 0 };
	char s2[50] = { 0 };
	gets(s1);
	gets(s2);
	int sz = strlen(s1);
	int ret = is_revolve(s1, s2, sz);
	printf("%d", ret);
	return 0;
}

思路2:

创建一个临时字符数组(tmp),将s1字符串拷贝两份存入临时字符数组.
使用strstr函数,判断字符串s2是否为tmp的字串.

涉及库函数:
strcmp函数:字符串拷贝函数
strcat函数:字符串追加函数
strstr函数:查找子字符串函数.

这些字符串操作函数会在后续更新其使用方法,参数,以及模拟实现.
在这里插入图片描述

#include <stdio.h>
#include <string.h>
#include <assert.h>
#define Max 100//定义零时字符串的最大长度
int is_revolve(const char* s1, char* s2,int sz)
{
	assert(s1 && s2);
	char tmp[Max];
	strcpy(tmp, s1);//将字符串1拷贝一份放入零时数组中
	strcat(tmp, s1);//使用字符串连接函数,将两个s1连接在一起
	if (strstr(tmp, s2) != NULL)//如果strstr函数返回的地址不是NULL说明,含有子字符串.
	{
		return 1;
	}
	else 0;//否则没有子字符串.
	
}
int main()
{
	char s1[50] = { 0 };//创建字符串s1
	char s2[50] = { 0 };//创建字符串s2;
	gets(s1);//获取字符串1
	gets(s2);//获取字符串2
	int sz = strlen(s1);//计算字符串长度
	int ret = is_revolve(s1, s2, sz);
	printf("%d", ret);
	return 0;
}

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

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

相关文章

如何通过Java将Word转换为PDF

Word是我们日常编辑文档内容时十分常用的一种文档格式。但相比之下&#xff0c;PDF文档的格式、布局更为固定&#xff0c;不易被更改。在保存或传输较为重要的文档内容时&#xff0c;PDF文档格式也时很多人的不二选择。很多时候我们都会遇到需要将Word转换为PDF的情况。下面我就…

放弃node-sass,启用sass

在下载一个新项目时运行&#xff1a;npm run install 发现报错 npm uninstall 异常 Error: Could not find any Visual Studio installation to use 或是 ------------------------- You need to install the latest version of Visual Studio npm ERR! gyp ERR! find VS incl…

嵌入式Linux(二十四)系统烧写

将uboot&#xff0c;linux kernel&#xff0c;.dtb&#xff0c;rootfs烧写到板子上的EMMC上&#xff0c;避免断网导致不能运行。 1. MfgTool工具介绍 一路解压之后&#xff0c;得到以下两项&#xff1a; ①Profiles文件夹&#xff1a;后续烧写文件放到这个文件夹。  其中关注…

宝塔+docker+jenkins部署vue项目(保姆级教程)

1.使用宝塔安装docker 在软件商城安装Docker管理器 2.使用docker下载jenkins镜像 使用命令行 docker pull jenkins/jenkins:lts //lts表示支持版本较长3.创建并且挂载jenkins目录并赋值 jenkins_home为我创建的目录 可以修改任意目录 mkdir -p /jenkins_home cho…

pytest测试框架——allure报告

文章目录一、allure的介绍二、allure的运行方式三、allure报告的生成方式一、在线报告、会直接打开默认浏览器展示当前报告方式二、静态资源文件报告&#xff08;带index.html、css、js等文件&#xff09;&#xff0c;需要将报告布置到web服务器上。四、allure中装饰器1、实现给…

【LeetCode每日一题:982. 按位与为零的三元组+从递归超时到记忆化搜索】

题目描述 给你一个整数数组 nums &#xff0c;返回其中 按位与三元组 的数目。 按位与三元组 是由下标 (i, j, k) 组成的三元组&#xff0c;并满足下述全部条件&#xff1a; 0 < i < nums.length 0 < j < nums.length 0 < k < nums.length nums[i] & …

Common API环境部署(保姆级教程,填充了很多坑)

Common API环境部署目录一、前言及结果展示二、Windows下安装docker1. 准备工作[1.1 Docker安装包](https://desktop.docker.com/win/main/amd64/Docker%20Desktop%20Installer.exe)[1.2 Wsl2安装包](https://wslstorestorage.blob.core.windows.net/wslblob/wsl_update_x64.ms…

【数据结构】链式二叉树

前言 在前面我们学习了一些二叉树的基本知识&#xff0c;了解了它的结构以及一些性质&#xff0c;我们还用数组来模拟二叉树建立了堆&#xff0c;并学习了堆排序&#xff0c;可是数组结构的二叉树有很大的局限性&#xff0c;平常我们用的最多树结构的还是链式二叉树&#xff0c…

【自律】学习方案

自律来源 轶事 陆奇以精力旺盛著称&#xff0c;通常凌晨4点起床&#xff0c;先查邮件&#xff0c;然后在跑步机上跑4英里&#xff0c;边跑边听古典音乐或看新闻。早上5点至6点至办公室&#xff0c;利用这段时间不受别人干扰准备一天的工作&#xff0c;然后一直工作到晚上10点&a…

搜索引擎的设计与实现

技术&#xff1a;Java、JSP等摘要&#xff1a;随着互联网的快速发展&#xff0c;网络上的数据也随着爆炸式地增长。如何最快速筛选出对我们有用的信息成了主要问题。搜索引擎是指根据一定的策略、运用特定的计算机程序从互联网上搜集信息&#xff0c;在对信息进行组织和处理后&…

ks通过恶意低绩效来变相裁员(五)绩效申诉就是「小六自证吃了一碗凉粉」

目录 一、小六吃了一碗凉粉 二、给你差绩效 公司告诉你可以绩效申诉 1、公司的实际目的是啥 2、你一旦自证&#xff0c;就掉入了陷阱 三、谁主张谁举证——让公司证明它绩效考核的客观性和公平性 四、针对公司的流氓恶意绩效行为&#xff0c;还有其他招吗 五、当公司用各…

学习方法--找书,背书,利器

学习方法 前言&#xff1a; 1、所谓的技术/技能&#xff0c;可比作对一类书的学习&#xff0c;那么第一步&#xff0c;就是要找这方面的书本来学习&#xff0c;简称为“找书”&#xff0c;找书既是指资料&#xff0c;也是指经验总结等等&#xff0c;第二步&#xff0c;就是背下…

【基础算法】双指针---数组元素的目标和

&#x1f339;作者:云小逸 &#x1f4dd;个人主页:云小逸的主页 &#x1f4dd;Github:云小逸的Github &#x1f91f;motto:要敢于一个人默默的面对自己&#xff0c;强大自己才是核心。不要等到什么都没有了&#xff0c;才下定决心去做。种一颗树&#xff0c;最好的时间是十年前…

CSS 基础:选择器、盒模型、布局

CSS&#xff08;Cascading Style Sheets&#xff09;是用于定义 HTML 或 XML 文档中的样式的一种语言。它可以控制网页的排版、字体、颜色、背景等多个方面&#xff0c;从而使网页呈现出美观的视觉效果和良好的用户体验。其中&#xff0c;选择器、盒模型和布局是 CSS 基础中的三…

Pod控制器

一.Pod控制器及其功用Pod控制器&#xff0c;又称之为工作负载&#xff08;workload&#xff09;&#xff0c;是用于实现管理pod的中间层&#xff0c;确保pod资源符合预期的状态&#xff0c;pod的资源出现故障时&#xff0c;会尝试进行重启&#xff0c;当根据重启策略无效&#…

C. Zero Path

给你一个矩阵&#xff0c;矩阵中每个点是1或者-1&#xff0c;问你是否存在一条路径从左上角到右下角路径上所经过点的总和是0。 类似于数字三角型&#xff0c;dp[i][j]可以用dp[i-1][j]的位置 和 dp[i][j-1]的位置传递过来&#xff0c;我们可以保存每个位置可以达成的和的所有可…

ROS小车研究笔记3/4/2023:自动导航launch文件解析

对于ROS小车导航算法基本原理和使用方法&#xff0c;可以看笔记http://t.csdn.cn/NUWHt 1 启动小车导航节点&#xff1a;turn_on_wheeltec_robot navigation.launch <launch><!-- 开启机器人底层相关节点 同时开启导航功能--><include file"$(find turn_on…

P6专题:如何通过P6 Professional创建及管理 EPS

目录 引言 创建EPS 引言 牢记P6数据结构&#xff0c;这是P6编制计划的层次&#xff1a;EPS-项目-WBS-作业。 EPS&#xff08;Enterprise Breakdown Structure&#xff09;&#xff1a;企业项目结构&#xff0c;用于组织项目&#xff0c;并进行数据汇总。EPS 代表 Primavera…

XFI和SFI的差异

目录 相同/相似点 应用参考模型 Trace Length 不同点 眼图模板 B点处的眼图模板对比 C点处的眼图模板对比 通道损耗 CDR支持 预加重和均衡 DC特性 RETIMER的用法 通过研究INF-8077i 10 Gigabit Small Form Factor Pluggable Module规范和SFF-8431 Specifications for …

【STM32】入门(十四):FreeRTOS-任务

1、简述 FreeRTOS应用程序由一组独立的任务构成。 在任何时间点&#xff0c;应用程序中只能执行一个任务&#xff0c;FreeRTOS调度器负责决定所要执行的任务。 每个任务在自己的上下文中执行&#xff0c;不依赖于系统内的其他任务或 FreeRTOS的调度器本身。 FreeRTOS调度器负责…