Using Hash Set to Determine if a String is the Permutation of An
- 时间:2020-09-09 13:08:38
- 分类:网络文摘
- 阅读:137 次
Given two strings s1 and s2, write an algorithm to determine if s1 is one permutation of s2.
For example:
s1 = “abc”, s2 = “bca”
output: true
s1 = “abc”, s2 = “bad”
output: false
Algorithm to Determine if a String is the Permutation of Another String
The fastest way to determine this is to use hash sets. If both strings (s1 and s2) are of different sizes, the result has to be false. Otherwise, we can convert both into two hash sets and simply compare the equality of both hash sets.
In C++, you can directly compare the the equality of both hash sets, either set (based on Red-Black Tree) or unordered_set (based on Hash Map):
1 2 3 4 5 6 7 8 9 | class Solution { public: bool CheckPermutation(string s1, string s2) { if (s1.size() != s2.size()) return false; unordered_set<char> a(begin(s1), end(s1)); unordered_set<char> b(begin(s2), end(s2)); return a == b; } }; |
class Solution {
public:
bool CheckPermutation(string s1, string s2) {
if (s1.size() != s2.size()) return false;
unordered_set<char> a(begin(s1), end(s1));
unordered_set<char> b(begin(s2), end(s2));
return a == b;
}
};Using unordered_set in C++, you will have a O(N) complexity however if you are using set (which keeps the keys in order by tree), the complexity is O(N.Log(N)).
In Python, we can do the same, with less code:
1 2 3 4 5 | class Solution: def CheckPermutation(self, s1: str, s2: str) -> bool: if len(s1) != len(s2): return False return set(s1) == set(s2) |
class Solution:
def CheckPermutation(self, s1: str, s2: str) -> bool:
if len(s1) != len(s2):
return False
return set(s1) == set(s2)–EOF (The Ultimate Computing & Technology Blog) —
推荐阅读:橄榄油真的是最好的食用油吗? 果胶:天然的食品添加剂和保健品 保健食品鱼目混珠要验明正身再认购 教你鉴别几种化了妆的常见水果 枸杞并非壮阳药,专家提醒勿乱服用 大量生吃皮蛋,小心“烧”伤口腔 食品安全绕不开的食品添加剂问题 没有食品添加剂,我们的生活会怎样? 黑豆补气抗衰老 黑色食品有保健奇效 蜂蜜是冬天补养佳品 滋阴润燥的食物
- 评论列表
-
- 添加评论