判断一个字符串是否为另外一个字符串旋转之后的字符串。

博客核心围绕判断一个字符串是否为另一个字符串旋转后的结果展开,涉及信息技术领域中字符串处理相关内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
void  reverse(char* start, char* end)
{
	while (start < end)
        {
		char temp = *start;
		*start = *end;
		*end = temp;
		start++;
		end--;
	}
}
void  left_rotate(char * str, int k)
{
	int  len = strlen(str);	
	reverse(str, str + k - 1);          //旋转前k个字符
	reverse(str + k, str + len - 1);    //旋转剩余的字符串
	reverse(str, str + len - 1);        //旋转整体
}
int is_rotate(char* dest, char* src)
{
	if (strlen(dest) != strlen(src))
        {
		return 0;
	}
	if (!strcmp(dest, src))
        {
		return 1;
	}
	int  k = strlen(dest);
	k--;
	while (k--){
		
		left_rotate(src, 1);          //每次旋转一次
		
		if (! strcmp(dest, src))      //判断旋转之后的内容是否和目标一致
                {
			return 1;
		}
	}
	return  0;
}
int  main()
{
	char dest[100];
	char src[100];
	scanf("%s", &dest);
	scanf("%s", &src);
	printf("%d\n", is_rotate(dest,src));
	system("pause");
	return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值