Using Hash Set to Determine if a String is the Permutation of An

  • 时间:2020-09-09 13:08:38
  • 分类:网络文摘
  • 阅读:134 次

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) —

推荐阅读:
分享茄子的家常做法,吃起来不油腻,营养美味又下饭  中华人民共和国慈善法(主席令第四十三号)  中华人民共和国深海海底区域资源勘探开发法(主席令第四十二号)  全国人民代表大会常务委员会关于修改《中华人民共和国人口与计划生育法》的决定(主席令第四十一号)  全国人大常委会关于修改《中华人民共和国高等教育法》的决定(主席令第四十号)  中华人民共和国反家庭暴力法(主席令第三十七号)  全国人大常委会关于修改《中华人民共和国教育法》的决定(主席令第三十九号)  中华人民共和国国家勋章和国家荣誉称号法(主席令第三十八号)  中华人民共和国反恐怖主义法(主席令第三十六号)  地图管理条例(国务院令第664号)  
评论列表
添加评论