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;
}

代码验证:

两字符串相同时:

两字符串不同时:

相关推荐
草莓熊Lotso2 小时前
【数据结构初阶】--算法复杂度的深度解析
c语言·开发语言·数据结构·经验分享·笔记·其他·算法
KyollBM2 小时前
【CF】Day75——CF (Div. 2) B (数学 + 贪心) + CF 882 (Div. 2) C (01Trie | 区间最大异或和)
c语言·c++·算法
CodeOfCC3 小时前
c语言 封装跨平台线程头文件
linux·c语言·windows
momo卡4 小时前
MinGW-w64的安装详细步骤(c_c++的编译器gcc、g++的windows版,win10、win11真实可用)
c语言·c++·windows
超的小宝贝5 小时前
数据结构算法(C语言)
c语言·数据结构·算法
凤年徐6 小时前
【数据结构初阶】单链表
c语言·开发语言·数据结构·c++·经验分享·笔记·链表
hjyowl15 小时前
题解:AT_abc407_c [ABC407C] Security 2
c语言·开发语言·算法
old_power16 小时前
UCRT 和 MSVC 的区别(Windows 平台上 C/C++ 开发相关)
c语言·c++·windows
@老蝴17 小时前
C语言 — 编译和链接
c语言·开发语言
LunaGeeking18 小时前
三分算法与DeepSeek辅助证明是单峰函数
c语言·c++·算法·编程·信奥赛·ai辅助学习·三分