【Java题解】面试题 01.09. 字符串轮转

字符串轮转。给定两个字符串s1和s2,请编写代码检查s2是否为s1旋转而成(比如,waterbottle是erbottlewat旋转后的字符串)。

示例1:

输入:s1 = “waterbottle”, s2 = “erbottlewat”
输出:True

示例2:

输入:s1 = “aa”, s2 = “aba”
输出:False

提示:

字符串长度在[0, 100000]范围内。

说明:

你能只调用一次检查子串的方法吗?

方法一:
暴力对比。

  1. 首先特判一下,s1,s2长度为0,return true; 否则:s1,s2任意一个为“” return false; 还有:s1,s2长度不等,return false;
  2. 在s2中找到所有s1开头字符的下标,然后进行循环判断,有任意一个与s1匹配了,return true。否则return false;

代码:

class Solution {
    public boolean isFlipedString(String s1, String s2) {
        // 暴力循环对比。
        if (s1.length() == 0 && s2.length() == 0) return true;
        if (s1.length() != s2.length() || s1.length() == 0 || s2.length() == 0) return false;
        char[] arr1 = s1.toCharArray();
        char[] arr2 = s2.toCharArray();
        ArrayList<Integer> idxs = findIdx(arr1, arr2);
        for (int i : idxs) 
            if (judge(arr1, arr2, i)) 
                return true;
        return false;
    }

    private ArrayList findIdx(char[] arr1, char[] arr2) {
        char c = arr1[0];
        ArrayList<Integer> idxs = new ArrayList<>();
        for (int i = 0; i < arr1.length; i++) {
            if (arr2[i] == c) idxs.add(i);
        }
        return idxs;
    }

    private boolean judge(char[] arr1, char[] arr2, int start) {
        int idx = 0;
        for (int i = start; idx < arr1.length; i++) {
            if (arr1[idx] != arr2[(i % arr1.length)]) return false;
            idx ++;
        }
        return true;
    }
}

时间复杂度:O(n + kn) 循环s2字符串寻找所有s1字符串首字符下标,并且,每个下标都要循环判断一遍s2字符串是否和s1匹配。
空间复杂度:O(m + n + k) m,n是两个字符串长度,k是s1字符串第一个字符重复的次数。

更好的解法待续…

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值