我有两个字符串a
和b
。我想知道a
是否是b
的轮换,反之亦然,而不创建第三个字符串。
答案 0 :(得分:1)
当且仅当存在L使得L == len(a)== len(b)并且存在偏移0< = j<时,字符串a是b的旋转。 len(a)使得对于所有0< = i< 1,[(i + j)%L] == b [i]。升。
在c代码中(假设L是字符串的公共长度。如果a是b的旋转,则返回1,否则返回0):
int i, j, is_rot;
for (i = 0; i< L; i++){
is_rot = 1;
for (j = 0; j<L; j++){
if (a[ (j + i) %L] != b[j] ){
is_rot = 0;
break;
}
}
if (is_rot) return 1;
}
return 0;