亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

leetcode中如何使數組唯一的最小增量

發布時間:2022-01-05 16:19:42 來源:億速云 閱讀:134 作者:小新 欄目:大數據

小編給大家分享一下leetcode中如何使數組唯一的最小增量,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

leetcode 每日一題

使數組唯一的最小增量


給定整數數組 A,每次 move 操作將會選擇任意 A[i],并將其遞增 1。

返回使 A 中的每個值都是唯一的最少操作次數。


示例 1:輸入:[1,2,2]
輸出:1解釋:經過一次 move 操作,數組將變為 [1, 2, 3]。


示例 2:輸入:[3,2,1,2,1,7]
輸出:6解釋:經過 6 次 move 操作,數組將變為 [3, 4, 1, 2, 5, 7]。可以看出 5 次或 5 次以下的 move 操作是不能讓數組的每個值唯一的。


提示:0 <= A.length <= 400000 <= A[i] < 40000


思路:

  • 排序后,每個元素都看看是否有重復元素,如果沒有重復元素,就pass,有重復元素,就+1

  • 排序后,其實就是前后兩個元素進行比較,如果前者小于或者不等于后者,則繼續,如果后者小于或者等于前者,則需要對元素進行處理

class Solution:    def minIncrementForUnique(self, A: List[int]) -> int:        if A is None or len(A) < 1:            return 0        length = len(A)        res = 0        A.sort()        '''         # 每個元素看列表中是否有重復元素        # 復雜度太高,超時不通過        for i in range(length):            value = A[i]            while self.uniq(A, value) is False:                value = value + 1                res += 1                A[i] = value        return res        '''        # 排序后,只要后面的一個比前面的一個大就略過        # 小于等于的話就需要變得比它大        for i in range(1, length):            if A[i] <= A[i-1]:                res += A[i-1] - A[i] + 1                A[i] = A[i-1] + 1  # 加1即可        return res
   def uniq(self, A, value):        count = 0        for v in A:            if v == value:                count += 1        if count > 1:            return False        else:            return True

以上是“leetcode中如何使數組唯一的最小增量”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

桓仁| 财经| 巴林左旗| 邢台市| 晋中市| 鸡东县| 高安市| 土默特左旗| 永胜县| 新田县| 文成县| 拉孜县| 瑞安市| 泗水县| 贺兰县| 如东县| 兴安县| 罗甸县| 星座| 凉城县| 泰州市| 夹江县| 炉霍县| 壤塘县| 玉门市| 红原县| 潍坊市| 土默特左旗| 东宁县| 高碑店市| 伊宁市| 凯里市| 永城市| 乐陵市| 蛟河市| 兰西县| 丹巴县| 张家口市| 贞丰县| 莱西市| 南开区|