董丕通


私信TA

用户名:dotcpp0726583

访问量:635

签 名:

等  级
排  名 1158
经  验 3142
参赛次数 4
文章发表 15
年  龄 0
在职情况 学生
学  校 淄博职业学院
专  业

  自我简介:

TA的其他文章


参考代码:

做法一:【寻找规律】

微信图片_20240206154123.png

可以发现, 两个字符串拼接起来的,包含全部位移的可能性

import java.util.Scanner;
public class Id2862 {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        String s1 = scan.next();
        String s2 = scan.next();
        if( s1.length() < s2.length() ) {
            String temp = s1;
            s1 = s2;
            s2 = temp;
        }
        scan.close();
        s1 = s1 + s1;
        if( s1.contains(s2) ) System.out.print(true);
        else System.out.print(false);
    }
}

做法二:【利用循环移动】

import java.util.Scanner;
public class Id2862 {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        String s1 = scan.next();
        String s2 = scan.next();
        scan.close();
        if( s1.length() < s2.length() ) {
                    String temp = s1;
                    s1 = s2;
                    s2 = temp;
                }
        for (int index = 0; index < s1.length(); index++) {
            if( s1.contains(s2) ) {
                System.out.println("true");
                return;
            }
            s1 = s1.substring(1) + s1.charAt(0);
        }
        System.out.println("false");
    }
}
这里循环次数的原因
// CDAA      假设是这个字符串     
// DAAC
// AACD
// ACDA
// CDAA     又回到原串,因此长度为几,移动几次就可以了


 

0.0分

1 人评分

  评论区

  • «
  • »