判断两个字符串是否互为旋转词

  

  如果一个字符串str,把字符串str前面的任意部分挪到后面形成的字符串叫做str的旋转词。给定两个字符串,判断是否互为旋转词。比如 a="abcd",b="cdab",true a="abcd",b="bcad",false

  

  【解题思路】

  如果长度不一样,肯定是false,如果长度一样,时间复杂度是O(N)。

  方法一:直接利用String的contains 方法

  方法二:看contains方法的源码,套用它的源码的方法

package com.test;

/**
 * Created by Demrystv.
 */
public class isRotation {


    /**
     * 方法一:直接利用String的contains 方法
     * @param a
     * @param b
     * @return
     */
    /*
    如果a 和b 的长度一样长,先生成一个大字符串b2, b2=b+b,即b2就是两个b 拼接起来的,然后看b2 中是否包含a,
    如果包含a, 说明a 和b 互为旋转词, 如果不包含,说明不是互为旋转词。
     */
    public boolean isRotation1(String a, String b){
        if (a == null || b == null || a.length() != b.length()){
            return false;
        }
        String b2 = b + b;
        return b2.contains(a);// 可以看其底层实现过程
    }


    /**
     * 方法二:看contains方法的源码,套用它的源码的方法
     * @param a
     * @param b
     * @return
     */

    public boolean isRotation2(String a, String b){
        if (a == null || b == null || a.length() != b.length()){
            return false;
        }
        String b2 = b + b;
        return indexOf(b2, a, 0) > -1;
    }

    private int indexOf(String b2, String a, int index){
        char[] source = b2.toCharArray();
        char[] target = a.toCharArray();
        return func(source, 0, source.length, target, 0, target.length, index);
    }

    private int func(char[] source, int sourceOffset, int sourceCount,
                        char[] target, int targetOffset, int targetCount,
                        int fromIndex) {
        if (fromIndex >= sourceCount) {
            return (targetCount == 0 ? sourceCount : -1);
        }
        if (fromIndex < 0) {
            fromIndex = 0;
        }
        if (targetCount == 0) {
            return fromIndex;
        }

        char first = target[targetOffset];
        int max = sourceOffset + (sourceCount - targetCount);

        for (int i = sourceOffset + fromIndex; i <= max; i++) {
            if (source[i] != first) {
                while (++i <= max && source[i] != first);
            }

            if (i <= max) {
                int j = i + 1;
                int end = j + targetCount - 1;
                for (int k = targetOffset + 1; j < end && source[j]
                        == target[k]; j++, k++);

                if (j == end) {
                    return i - sourceOffset;
                }
            }
        }
        return -1;
    }

}