1071. 字符串的最大公因子

题目

对于字符串 st,只有在 s = t + ... + tt 自身连接 1 次或多次)时,我们才认定 “t 能除尽 s”。

给定两个字符串 str1str2 。返回 最长字符串 x,要求满足 x 能除尽 str1X 能除尽 str2

示例 1:

1
2
输入:str1 = "ABCABC", str2 = "ABC"
输出:"ABC"

示例2:

1
2
输入:str1 = "ABABAB", str2 = "ABAB"
输出:"AB"

示例3:

1
2
输入:str1 = "LEET", str2 = "CODE"
输出:""

提示:

  • 1 <= str1.length, str2.length <= 1000
  • str1str2 由大写英文字母组成

解法

解法一:

JAVA

1
2
3
4
5
6
7
8
9
10
11
public String gcdOfStrings(String str1, String str2) {
if (!(str1 + str2).equals(str2 + str1)) {
return "";
}

return str1.substring(0, gcd(str1.length(), str2.length()));
}

private int gcd(int a, int b) {
return b == 0 ? a : gcd(b, a % b);
}
0%