鱼C论坛

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

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

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

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

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

x
使用字符串 常用类的方法
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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


滑动窗口暴力解:

  1. import java.util.HashSet;
  2. import java.util.Scanner;
  3. import java.util.Set;

  4. /**
  5. * @Classname PrintSubString
  6. * @Description :
  7. * @Date 2022/4/19 20:21
  8. * @Created by Twilight6
  9. */

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

  18.     public static Set<String> printSubString(String str){
  19.         Set<String> set = new HashSet<>();
  20.         if (str == null || str.length() == 0){
  21.             return set;
  22.         }
  23.         int len = str.length();
  24.         int l = 0, r = 1;
  25.         while (r <= len){
  26.             for (int i = 0; i + r <= len; i++){
  27.                 String substring = str.substring(l + i, r + i);
  28.                 set.add(substring);
  29.             }
  30.             r++;
  31.         }
  32.         return set;
  33.     }
  34. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-5-15 03:15

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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