0. 极简实现
将问题转换为统计各个字母的出现顺序:
from collections import Counter
Counter(str1) == Counter(str2)
1. 等价表述
该问题还可进一步表述为:给定两个字符串,判断其中一个字符串的字符重新排列后,是否能变为另一个字符串。
2. 等价实现
如果继续采用计数的思想,如何判断两个词频是一致的呢:
-
Java 实现
public static boolean canPerm(String s, String t) { if (s.length() != t.length()) { return false; } int[] counter = new int[256]; for (char c : s.toCharArray()) { counter[c]++; } // 两字符串长度一致的前提下, for (char c : t.toCharArray()) { if (--counter[c] < 0) { return false; } } return true; }
-
Python 实现
def is_equal_chars(str1, str2): cnt = {} if len(str1) != len(str2): return False for c in str1: cnt[c] = cnt.get(c, 0) + 1 for c in str2: if c not in cnt: return False # 两字符串长度一致 cnt[c] -= 1 if cnt[c] < 0: return False return True