Medium
Two strings are considered close if you can attain one from the other using the following operations:
abcde -> aecdb
aacabb -> bbcbaa
(all a
’s turn into b
’s, and all b
’s turn into a
’s)You can use the operations on either string as many times as necessary.
Given two strings, word1
and word2
, return true
if word1
and word2
are close, and false
otherwise.
Example 1:
Input: word1 = “abc”, word2 = “bca”
Output: true
Explanation: You can attain word2 from word1 in 2 operations.
Apply Operation 1: “abc” -> “acb”
Apply Operation 1: “acb” -> “bca”
Example 2:
Input: word1 = “a”, word2 = “aa”
Output: false
Explanation: It is impossible to attain word2 from word1, or vice versa, in any number of operations.
Example 3:
Input: word1 = “cabbba”, word2 = “abbccc”
Output: true
Explanation: You can attain word2 from word1 in 3 operations.
Apply Operation 1: “cabbba” -> “caabbb”
Apply Operation 2: "
caabbb” -> “baaccc”
Apply Operation 2: “baaccc” -> “abbccc”
Constraints:
1 <= word1.length, word2.length <= 105
word1
and word2
contain only lowercase English letters.class Solution {
fun closeStrings(word1: String, word2: String): Boolean {
if (word1.length != word2.length) {
return false
}
if (word1 == word2) {
return true
}
val freq1 = IntArray(26)
val freq2 = IntArray(26)
for (c in word1.toCharArray()) {
freq1[c.code - 'a'.code]++
}
for (c in word2.toCharArray()) {
freq2[c.code - 'a'.code]++
}
for (i in 0..25) {
if (freq1[i] == 0 && freq2[i] != 0 || freq1[i] != 0 && freq2[i] == 0) {
return false
}
}
freq1.sort()
freq2.sort()
return freq1.contentEquals(freq2)
}
}