• <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
            給出一串可能重復(fù)的數(shù),輸出所有排列數(shù),要求去重

            思路一:Python的生成排列的函數(shù),再去重(需要先排序,方便后續(xù)去重,非常耗時(shí)且需要更多Memory):
            Runtime: 575 ms, faster than 31.05% of Python online submissions for Permutations II.
            Memory Usage: 20.6 MB, less than 5.10% of Python online submissions for Permutations II.

             1 #47
             2 #Runtime: 575 ms
             3 #Memory Usage: 20.6 MB
             4 
             5 class Solution(object):
             6     def permuteUnique(self, nums):
             7         """
             8         :type nums: List[int]
             9         :rtype: List[List[int]]
            10         """
            11         nums.sort()
            12         t_ans = list(permutations(nums))
            13         ans = []
            14         ans.append(t_ans[0])
            15         for i in range(1, len(t_ans)):
            16             fg = 0
            17             nt = 0
            18             for j in range(0, len(t_ans[i])):
            19                 if t_ans[i][j] == ans[-1][j]:
            20                     nt += 1
            21                 if j > 0 and t_ans[i][j - 1] == ans[-1][j - 1] and t_ans[i][j] < ans[-1][j]:
            22                     fg = 1
            23                     break
            24             if fg == 0 and nt < len(nums):
            25                 ans.append(t_ans[i])
            26         return ans

            思路二:用Python的Counter函數(shù)記錄每一種數(shù)字出現(xiàn)的次數(shù),在DFS時(shí)只記錄是否每個(gè)數(shù)字用完了,而不是每一位是否visit,以達(dá)到去重作用

             1 #47
             2 #Runtime: 77 ms
             3 #Memory Usage: 13.8 MB
             4 
             5 class Solution(object):
             6     
             7     def permuteUnique(self, nums):
             8         """
             9         :type nums: List[int]
            10         :rtype: List[List[int]]
            11         """
            12         vis = Counter(nums)
            13         self.res = []
            14         self.dfs(nums, vis, [])
            15         return self.res   
            16 
            17     def dfs(self, nums, vis, s):
            18         if len(s) == len(nums):
            19             self.res.append(list(s))
            20             return
            21         else:
            22             for i in vis:
            23                 if vis[i] > 0:
            24                     vis[i] -= 1
            25                     s.append(i)
            26                     self.dfs(nums, vis, s)
            27                     s.pop()
            28                     vis[i] += 1






            人妻久久久一区二区三区| 国产三级精品久久| 久久久久久久综合狠狠综合| 久久午夜电影网| 精品一区二区久久久久久久网站| 新狼窝色AV性久久久久久| 亚洲精品无码久久久久久| 97香蕉久久夜色精品国产 | 久久久久亚洲AV成人网| 99热热久久这里只有精品68| 国产成人精品久久亚洲高清不卡| 久久伊人精品青青草原高清| 99久久综合国产精品二区| 久久久久亚洲AV无码专区网站| 亚洲欧洲精品成人久久奇米网| 污污内射久久一区二区欧美日韩| 久久综合亚洲色一区二区三区| 日韩AV无码久久一区二区| 国产午夜福利精品久久2021| 青青青青久久精品国产h| 久久强奷乱码老熟女网站| 超级碰碰碰碰97久久久久| 精品久久久噜噜噜久久久| 久久福利青草精品资源站| 欧美久久一区二区三区| 午夜欧美精品久久久久久久| 久久香蕉国产线看观看99| 久久久国产精品| 久久久久人妻一区二区三区vr | 伊人久久免费视频| 亚洲?V乱码久久精品蜜桃 | 国产成人精品久久综合| 久久夜色精品国产噜噜亚洲a | 久久99国产精品久久久| 久久无码国产| 国产精品久久久久影视不卡| 久久人人爽人人爽人人片AV东京热| 亚洲第一极品精品无码久久| 91久久精品视频| 久久久久亚洲av无码专区喷水| 久久乐国产精品亚洲综合|