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

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

例如:给定s1 = AABCD和s2 = BCDAA,返回1,给定s1=abcd和s2=ACBD,返回0.


#include 
   
   
    
    
#include 
    
    
     
     
#include 
     
     
      
      
void shiftstep(char *msg, int step)
{
	assert(msg);
	int len = strlen(msg);
	step = step%len;
	reverse(msg, msg + step - 1);
	reverse(msg + step, msg + len - 1);
	reverse(msg, msg + len - 1);
}
reverse(char *start, char *end)
{
	assert(start);
	assert(end);
	while (start < end)
	{
		*start = *start^*end;
		*end = *start^*end;
		*start = *start^*end;
		start++;
		end--;
	}
}
int find(char *str, char *substr)
{
	assert(str);
	assert(substr);
	int len = strlen(str);
	if (len == strlen(substr))
	{
		char *_str = (char *)malloc(2 * len + 1);
		strcpy(_str, str);
		strcat(_str, str);
		if ((strstr(_str, substr)) != NULL)
		{
			return 1;
		}
		free(_str);
	}
	return 0;
}

int main()
{
	char str[] = "123456";
	char substr[] = "7894";
	shiftstep(str, 0);
	printf("%d\n", find(str, substr));
	return 0;
}
     
     
    
    
   
   

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值