Given two strings s and t, write a function to determine if t is an anagram of s.
For example,
s = “anagram”, t = “nagaram”, return true.
s = “rat”, t = “car”, return false.
Note:
You may assume the string contains only lowercase alphabets.
Follow up:
What if the inputs contain unicode characters? How would you adapt your solution to such case?
判断给定两个字符串是否为相同字母不同排列的单词。
最简单的办法就是调用stl的排序函数sort给两个字符串s和t排序,然后比较是否相等即可,复杂度为O(nlogn);
如果嫌弃复杂度太高,还可以采用另外一种办法求每个字符个数判相等(题目已经假设只有小写字母那么也就只有26个),比较是否相等,复杂度为O(n);
我想到用map记录,然后看map是否equals。
public boolean isAnagram(String s, Stri

该博客探讨了如何确定两个字符串是否是字母异位词,即它们包含相同的字母但顺序不同。提供了使用排序和计数两种算法方法,分别具有O(nlogn)和O(n)的时间复杂度。还提到了考虑Unicode字符时的解决方案。
订阅专栏 解锁全文
665

被折叠的 条评论
为什么被折叠?



