原文链接: https://leetcode-cn.com/problems/check-whether-two-strings-are-almost-equivalent
英文原文
Two strings word1
and word2
are considered almost equivalent if the differences between the frequencies of each letter from 'a'
to 'z'
between word1
and word2
is at most 3
.
Given two strings word1
and word2
, each of length n
, return true
if word1
and word2
are almost equivalent, or false
otherwise.
The frequency of a letter x
is the number of times it occurs in the string.
Example 1:
Input: word1 = "aaaa", word2 = "bccb" Output: false Explanation: There are 4 'a's in "aaaa" but 0 'a's in "bccb". The difference is 4, which is more than the allowed 3.
Example 2:
Input: word1 = "abcdeef", word2 = "abaaacc" Output: true Explanation: The differences between the frequencies of each letter in word1 and word2 are at most 3: - 'a' appears 1 time in word1 and 4 times in word2. The difference is 3. - 'b' appears 1 time in word1 and 1 time in word2. The difference is 0. - 'c' appears 1 time in word1 and 2 times in word2. The difference is 1. - 'd' appears 1 time in word1 and 0 times in word2. The difference is 1. - 'e' appears 2 times in word1 and 0 times in word2. The difference is 2. - 'f' appears 1 time in word1 and 0 times in word2. The difference is 1.
Example 3:
Input: word1 = "cccddabba", word2 = "babababab" Output: true Explanation: The differences between the frequencies of each letter in word1 and word2 are at most 3: - 'a' appears 2 times in word1 and 4 times in word2. The difference is 2. - 'b' appears 2 times in word1 and 5 times in word2. The difference is 3. - 'c' appears 3 times in word1 and 0 times in word2. The difference is 3. - 'd' appears 2 times in word1 and 0 times in word2. The difference is 2.
Constraints:
n == word1.length == word2.length
1 <= n <= 100
word1
andword2
consist only of lowercase English letters.
中文题目
如果两个字符串 word1
和 word2
中从 'a'
到 'z'
每一个字母出现频率之差都 不超过 3
,那么我们称这两个字符串 word1
和 word2
几乎相等 。
给你两个长度都为 n
的字符串 word1
和 word2
,如果 word1
和 word2
几乎相等 ,请你返回 true
,否则返回 false
。
一个字母 x
的出现 频率 指的是它在字符串中出现的次数。
示例 1:
输入:word1 = "aaaa", word2 = "bccb" 输出:false 解释:字符串 "aaaa" 中有 4 个 'a' ,但是 "bccb" 中有 0 个 'a' 。 两者之差为 4 ,大于上限 3 。
示例 2:
输入:word1 = "abcdeef", word2 = "abaaacc" 输出:true 解释:word1 和 word2 中每个字母出现频率之差至多为 3 : - 'a' 在 word1 中出现了 1 次,在 word2 中出现了 4 次,差为 3 。 - 'b' 在 word1 中出现了 1 次,在 word2 中出现了 1 次,差为 0 。 - 'c' 在 word1 中出现了 1 次,在 word2 中出现了 2 次,差为 1 。 - 'd' 在 word1 中出现了 1 次,在 word2 中出现了 0 次,差为 1 。 - 'e' 在 word1 中出现了 2 次,在 word2 中出现了 0 次,差为 2 。 - 'f' 在 word1 中出现了 1 次,在 word2 中出现了 0 次,差为 1 。
示例 3:
输入:word1 = "cccddabba", word2 = "babababab" 输出:true 解释:word1 和 word2 中每个字母出现频率之差至多为 3 : - 'a' 在 word1 中出现了 2 次,在 word2 中出现了 4 次,差为 2 。 - 'b' 在 word1 中出现了 2 次,在 word2 中出现了 5 次,差为 3 。 - 'c' 在 word1 中出现了 3 次,在 word2 中出现了 0 次,差为 3 。 - 'd' 在 word1 中出现了 2 次,在 word2 中出现了 0 次,差为 2 。
提示:
n == word1.length == word2.length
1 <= n <= 100
word1
和word2
都只包含小写英文字母。
通过代码
高赞题解
func checkAlmostEquivalent(word1, word2 string) bool {
diff := [26]int{} // 统计每个字符的频率差值
for _, ch := range word1 {
diff[ch-'a']++
}
for _, ch := range word2 {
diff[ch-'a']--
}
for _, d := range diff {
if d < -3 || d > 3 {
return false
}
}
return true
}
统计信息
通过次数 | 提交次数 | AC比率 |
---|---|---|
3315 | 4468 | 74.2% |
提交历史
提交时间 | 提交结果 | 执行时间 | 内存消耗 | 语言 |
---|