字符串的最大公因子
对于字符串 s 和 t,只有在 s = t + t + t + ... + t + t(t 自身连接 1 次或多次)时,我们才认定 “t 能除尽 s”。
给定两个字符串 str1 和 str2 。返回 最长字符串 x,要求满足 x 能除尽 str1 且 x 能除尽 str2 。
示例 1:
输入:str1 = "ABCABC", str2 = "ABC"
输出:"ABC"
示例 2:
输入:str1 = "ABABAB", str2 = "ABAB"
输出:"AB"
示例 3:
输入:str1 = "LEET", str2 = "CODE"
输出:""
提示:
1 <= str1.length, str2.length <= 1000
str1 和 str2 由大写英文字母组成
解法1
class Solution {public String gcdOfStrings(String str1, String str2) {// 如果拼接结果不同,说明不存在公共除字符串if (!(str1 + str2).equals(str2 + str1)) {return "";}// 最大公因数长度int gcdLength = gcd(str1.length(), str2.length());// 若存在公共除字符串,则长度一定为两串长度的最大公约数return str1.substring(0, gcdLength);}private int gcd(int a, int b) {return b == 0 ? a : gcd(b, a % b);}
}
