C语言 ——— 写一个函数,判断一个字符串是否为另外一个字符串旋转之后的字符串

目录

题目要求

代码思路

代码实现


题目要求

写一个函数,判断一个字符串是否为另外一个字符串旋转之后的字符串

例如

s1 = "AABCD" ;s2 = "BCDAA" ,返回1

s1 = "AABcd" ;s2 = "BCDAA" ,返回0


代码思路

每次将 s1 左旋1个字符串,然后和 s2 判断是否相等即可

左旋实现代码:C语言 --------- 实现一个函数,使字符串左旋-CSDN博客


代码实现

复制代码
#include<stdio.h>
#include<string.h>
#include<assert.h>
void Levorotation_Str(char* str)
{
	size_t len = strlen(str);

	char tmp = str[0];

	int i = 0;
	for (int i = 0; i < len - 1; i++)
	{
		str[i] = str[i + 1];
	}

	str[len - 1] = tmp;
}
int Is_Left_Move(char* str1, char* str2)
{
	assert(str1 && str2);

	// 判断两个字符串是否等长
	if (strlen(str1) != strlen(str2))
		return 0;

	for (int i = 0; i < strlen(str1); i++)
	{
		// str1 字符串每次左旋一个字符,再判断是否等同于 str2 字符串

		Levorotation_Str(str1);

		if (strcmp(str1, str2) == 0)
			return 1;
	}

	return 0;
}
int main()
{
	char arr1[] = "AABCDEF";
	char arr2[] = "BCDEFAA";

	int ret = Is_Left_Move(arr1, arr2);

	if (ret == 1)
	{
		printf("Yes\n");
	}
	else
	{
		printf("No\n");
	}

	return 0;
}

代码验证:

两字符串相同时:

两字符串不同时:

相关推荐
CQ_YM18 小时前
Linux管道通信
linux·c语言·管道·ipc·管道通信
Sunsets_Red19 小时前
2025 FZYZ夏令营游记
java·c语言·c++·python·算法·c#
红豆诗人21 小时前
数据结构初阶知识--单链表
c语言·数据结构
智者知已应修善业1 天前
【蓝桥杯龟兔赛跑】2024-2-12
c语言·c++·经验分享·笔记·算法·职场和发展·蓝桥杯
d111111111d1 天前
C语言中,malloc和free是什么,在STM32中使用限制是什么,该如何使用?
c语言·开发语言·笔记·stm32·单片机·嵌入式硬件·学习
李白同学1 天前
Linux:调试器-gdb/cgdb使用
linux·服务器·c语言·c++
黎雁·泠崖1 天前
指针家族高阶篇:字符指针、数组指针、函数指针及转移表应用
c语言·开发语言
未来之窗软件服务1 天前
幽冥大陆(五十七)ASR whisper-cli命令行使用 C语言—东方仙盟筑基期
c语言·开发语言·whisper·仙盟创梦ide·东方仙盟·东方仙盟自动化·东方仙盟商业开发
程芯带你刷C语言简单算法题1 天前
Day33~实现一个算法来识别一个字符串。
c语言·算法·c
yyy(十一月限定版)1 天前
c语言——二叉树
c语言·开发语言·数据结构