• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Uriel's Corner

            Research Associate @ Harvard University / Research Interests: Computer Vision, Biomedical Image Analysis, Machine Learning
            posts - 0, comments - 50, trackbacks - 0, articles - 594
            給出s1和s2兩個字符串,其中的字符一一對應,這樣的一一對應關系符合:

            Reflexivity: 'a' == 'a'.
            Symmetry: 'a' == 'b' implies 'b' == 'a'.
            Transitivity: 'a' == 'b' and 'b' == 'c' implies 'a' == 'c'.

            另給出一個baseStr,輸出與之對等的字符排序最小的字符串
            并查集,將s1和s2對應位置的字符一一并入相同集合,注意在合并時永遠選擇較小的字符作為父節點

             1 #1061
             2 #Runtime: 26 ms (Beats 87.50%)
             3 #Memory: 13.5 MB (Beats 81.25%)
             4 
             5 class UnionFind:
             6     def __init__(self):
             7         self.parent = {}
             8     def find(self, x):
             9         if x not in self.parent:
            10             self.parent[x] = x
            11         i = x
            12         while x != self.parent[x]:
            13             x = self.parent[x]
            14         self.parent[i] = x
            15         return x
            16     def union(self, x, y):
            17         rx = self.find(x)
            18         ry = self.find(y)
            19         if rx > ry:
            20             self.parent[rx] = ry
            21         else:
            22             self.parent[ry] = rx
            23 
            24 class Solution(object):
            25     def smallestEquivalentString(self, s1, s2, baseStr):
            26         """
            27         :type s1: str
            28         :type s2: str
            29         :type baseStr: str
            30         :rtype: str
            31         """
            32         uf = UnionFind()
            33         for i in range(len(s1)):
            34             uf.union(s1[i], s2[i])
            35         ans = []
            36         for c in baseStr:
            37             ans.append(uf.find(c))        
            38         return ''.join(ans)
            久久精品人人做人人爽电影| 人妻丰满AV无码久久不卡| 人人狠狠综合久久亚洲88| 久久久久人妻一区精品| 亚洲人成伊人成综合网久久久| 2022年国产精品久久久久| 四虎国产精品免费久久久| 亚洲欧美日韩精品久久亚洲区 | 久久精品一本到99热免费| 99久久婷婷国产综合亚洲| 日韩电影久久久被窝网| 精品一二三区久久aaa片| 欧美激情精品久久久久| 久久大香萑太香蕉av| 久久成人国产精品二三区| 无码国内精品久久人妻蜜桃 | 国产精品久久久久久久人人看| 69久久精品无码一区二区| 伊人久久大香线蕉无码麻豆| 91精品国产91久久| 久久亚洲精精品中文字幕| 久久婷婷色综合一区二区| 久久免费视频6| 精品国产乱码久久久久久浪潮| 国产精品99久久久久久人| 久久精品国产亚洲AV无码麻豆| 奇米影视7777久久精品人人爽| 久久久久久国产a免费观看不卡| 国产激情久久久久影院老熟女免费| 婷婷综合久久中文字幕蜜桃三电影| 久久免费视频1| 亚洲欧洲日产国码无码久久99| 伊人色综合九久久天天蜜桃| 香港aa三级久久三级老师2021国产三级精品三级在 | 久久久久18| 亚洲国产成人久久精品99 | 日韩精品无码久久久久久| 狠狠色综合网站久久久久久久高清| 偷偷做久久久久网站| 国内精品久久国产| 99久久精品免费看国产一区二区三区 |