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

本文介绍两种判断一个字符串是否为另一个字符串旋转后的结果的算法。一种是通过循环对比所有旋转情况,另一种是通过检查拼接后的字符串中是否包含目标字符串。

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

题目描述】:
例如:给定s1 =AABCD和s2 = BCDAA,返回1,给定s1=abcd和s2=ACBD,返回0.
AABCD左旋一个字符得到ABCDA
AABCD左旋两个字符得到BCDAA
AABCD右旋一个字符得到DAABC

解题思路一】:
可以将字符串AABCD的所有旋转后的情况利用循环依次和BCDAA进行对比,如果相同返回1,否则返回0。

参考代码】:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int judge(char str1[], char str2[]) {
 int i = 0;
 int j = 0;
 int length = strlen(str1);
 for (j = 1; j <= length; j++) {
   int temp = str1[0];
   for (i = 0; i < length - 1; i++) {
    str1[i] = str1[i + 1];
   }
   str1[length - 1] = temp;
  if (0 == strcmp(str1, str2)) {
   return 1;
  }
 }
 return 0;
}
int main() {
 char s1[10] = "AABCD";
 char s2[10] = "BCDAA";
 printf("s1 = %s\n", s1);
 printf("s2 = %s\n", s2);
 printf("%d\n", judge(s1, s2));
 system("pause");
 return 0;
}

解题思路二】:
根据左旋或右旋结果和原字符串的联系,可以将一个给定的字符串拷贝一份放在该字符串的后面得到新的字符串,只需要判断另一个字符串是不是组合的新字符串的子字符串就可以解决问题。

例如:给定的一个字符串为ABCDE,经过拷贝后的字符串为ABCDEABCDE,观察这个字符串,能够发现给定的字符串ABCDE经过左、右旋的所有情况为字符串ABCDEABCDE的子串。

参考代码】:

#define  _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.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[] = "AABCD";
 char arr[1024];
 char s2[] = "BCDAA";
 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、付费专栏及课程。

余额充值