c语言实现:判断一个字符串是否为另外一个字符串旋转之后的字符串。 例如:给定s1 =AABCD和s2 = BCDAA,返回1 给定s1=abcd和s2=ACBD,返回0.(两种方法)

判断一个字符串是否为另外一个字符串旋转之后的字符串。
例如:给定s1 =AABCD和s2 = BCDAA,返回1
给定s1=abcd和s2=ACBD,返回0.

方法1:采用左旋的方法?
#include<stdio.h>
#include<string.h>
#include<Windows.h>
#pragma warning(disable:4996)
void left_move(char *str, int k)//左旋str字符串
{	
	while (k != 0)	
	{		
		char *cur = str;		
		char tmp = *cur;		
		while ((*(cur + 1)) != '\0')		
		{			
			*cur = *(cur + 1);			
			cur++;		
		}		
		*(cur) = tmp;		
		k--;	
	}
}
int Judge_string(char *str, const char *p)//判断函数
{	
	int i;	
	if (strlen(str) != strlen(p))	
	{		
		return 0;	
	}	
	for (i = 1; i <= strlen(str); i++)	
	{		
		left_move(str, 1);		
		if (strcmp(str, p) == 0)//strcmp函数判断str字符串是否与p字符串相同		
		{			
			return 1;		
		}	
	}	
	return 0;
}
int main()
{	
	char str1[] = "abcd";	
	char str2[] = "cdab";	
	printf("%d\n", Judge_string(str1, str2));
	system("pause");	
	return 0;
}
方法2:采用字符串拼接的方法
#pragma warning(disable:4996)
#include <stdio.h>
#include <Windows.h>
#include <string.h>
int judge(char str1[], char arr[], char str2[]) 
{	
	char *a = arr;	char *s = str1;	//判断两个字符串的长度,如果长度不一样就不可能是源字符串旋转后的结果	
	if (strlen(str1) != strlen(str2)) 
	{		
		return 0;	
	}	//将两个str1字符串合并	
	while (*a) 
	{		
		a++;	
	}	
	while (*s) 
	{		
		*a++ = *s++;	
	}	//strstr函数判断后面函数是不是前面函数的子字符串	
	char *ret = NULL;	
	ret = strstr(arr, str2);	
	if (ret != NULL) 
	{		
		return 1;	
	}	
	return 0;
}
int main() 
{	
	char s1[] = "abcdef";	
	char arr[1024];	
	char s2[] = "bcdefa";	
	strcpy(arr, s1);	
	if (judge(s1, arr, s2)) 
	{		
		printf("%s 是 %s 旋转之后的字符串!\n", s2, s1);	
	}	
	else 
	{		
		printf("%s 不是 %s 旋转之后的字符串!\n", s2, s1);	
	}	
	system("pause");	
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值