Java 输出给定字符串的重复子串及子串的重复次数

笔试遇到的算法题


// 给定字符串,输出其子串重复次数以及重复的子串
// "ysysys" -> "3 ys"
// "aaaaa" -> "5 a"
// "ysysysy" -> "1 ysysysy"
public class SubStringAndCount {
    public static void main(String[] args) {

        String string = "aaaaaa";
        int len = string.length();

        if (!judge(string)) {
            System.out.println("1 " + string);
        } else {

            for (int i = 1; i < len / 2; i++) {
                if (len % i == 0) {
                    boolean match = true;
                    int count = 0;  // 重复的子串数量
                    for (int j = 0; j < len / 2; j++) {
                        if (string.charAt(j) != string.charAt(j + i)) {
                            match = false;
                            break;
                        } else {
                            count++;
                        }
                    }
                    if (match) {
                        System.out.println(len / i + " " + string.substring(0, i));
                        break;
                    }
                }
            }

        }

    }

    // 判断字符串是否由重复子串组成
    public static boolean judge(String s) {
        String str = s + s;
        return str.substring(1, str.length() - 1).contains(s);
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值