鱼C论坛

 找回密码
 立即注册
查看: 3213|回复: 1

输入一个字符串,输出该字符串的所有子串(不能重复),所有子串个数小于100个

[复制链接]
发表于 2022-4-19 19:54:04 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
使用字符串 常用类的方法
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-4-19 20:28:46 | 显示全部楼层


滑动窗口暴力解:
import java.util.HashSet;
import java.util.Scanner;
import java.util.Set;

/**
 * @Classname PrintSubString
 * @Description :
 * @Date 2022/4/19 20:21
 * @Created by Twilight6
 */

public class PrintSubString {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        System.out.print(">>> ");
        String s = scan.nextLine();
        Set<String> strings = printSubString(s);
        strings.forEach(System.out::println);
    }

    public static Set<String> printSubString(String str){
        Set<String> set = new HashSet<>();
        if (str == null || str.length() == 0){
            return set;
        }
        int len = str.length();
        int l = 0, r = 1;
        while (r <= len){
            for (int i = 0; i + r <= len; i++){
                String substring = str.substring(l + i, r + i);
                set.add(substring);
            }
            r++;
        }
        return set;
    }
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-22 13:05

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表