a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 學院 > 開發設計 > 正文

357. Count Numbers with Unique Digits -Medium

2019-11-11 05:12:04
字體:
來源:轉載
供稿:網友

Question

Given a non-negative integer n, count all numbers with unique digits, x, where 0 ≤ x < 10n.

給出一個非負整數n,在 0 <= x <10 ^n 的范圍內,統計每一位都不重復的數字的個數

Example

Given n = 2, return 91. (The answer should be the total numbers in the range of 0 ≤ x < 100, excluding [11,22,33,44,55,66,77,88,99])

Solution

想到的第一種方法是回溯,在個位數遍歷1 - 9,在其他位數上遍歷0-9(當然要注意已使用過的數字不能再使用),終止條件為當前的數字大于最大的數字(10 ^ n)

class Solution(object): def countNumbersWithUniqueDigits(self, n): """ :type n: int :rtype: int """ count = 1 # 因為個位數不能有0,所以個位數的循環放到回溯外面,分別統計一次個位數為 1 - 9 的元素不重復數字個數 for i in range(1, 10): selectable = list(range(10)) selectable.remove(i) count += self.solve(list(range(2, 10)), pow(10, n), i) return count def solve(self, selectable, max_num, current_num): count = 0 # 只要小于最大數字,都保存統計,否則返回 if current_num < max_num: count += 1 else: return count # 遍歷 0 - 9 數字 for index_s, s in enumerate(selectable): count += self.solve(selectable[:index_s] + selectable[index_s + 1:], max_num, current_num * 10 + s) return count

不過得到了 Time Limit Exceeded

第二種方法是動態規劃。

位數 不重復元素個數 總數
1 10 10
2 9 * 9 91
3 9 * 9 * 8 739
4 9 * 9 * 8 * 7 986410

考慮以上規律,我們只需保存兩個變量,一個是上一個位數的不重復元素個數dp,另一個是可選數字個數selectable,這樣我們就可以得到遞推式 dp = dp * selectable,同時我們額外在維護一個總數就可以了

class Solution(object): def countNumbersWithUniqueDigits(self, n): """ :type n: int :rtype: int """ if n == 0: return 1 selectable = 9 # 當前可選項個數 dp = 9 # 保存當前位數的元素不重復數字個數(不包括個位數) res = 10 # 元素不重復數字的總個數 # 個位數的情況已經統計完成了,所以只需要統計n - 1次 for _ in range(n - 1): if selectable > 0: dp = dp * selectable res += dp selectable -= 1 return res
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 影音先锋国产 | 国内精品久久久久久久影视蜜臀 | 国产 日韩 欧美 制服 另类 | 亚洲精品久久视频 | 国产精品久久精品 | 欧美1区| 五月婷婷在线观看 | 欧美日韩在线观看中文字幕 | va在线| 亚洲高清视频在线观看 | www日本xxx| 91精品国产综合久久久亚洲 | 午夜www | 成人av一区 | 亚洲经典自拍 | 午夜精品久久久久久99热软件 | 色婷婷综合五月天 | 在线免费观看的www视频 | 亚洲精品视频在线播放 | 国产成人精品一区二 | 日本免费黄色 | 久久综合狠狠综合久久综合88 | 成人免费视频在线观看 | 中文字幕不卡在线观看 | 久久艹国产视频 | 日韩福利在线 | 成人观看免费视频 | 成人天堂噜噜噜 | av毛片在线免费看 | 欧美成人一区二区三区片免费 | 亚洲精品在线看 | 成人爽a毛片免费啪啪动漫 日本特级片 | 最新免费av网站 | 国产精品国产三级国产普通话蜜臀 | 99久久精品免费看国产免费粉嫩 | 天天想天天干 | 日中文字幕在线 | 久久污视频 | 欧美日韩国产精品久久久久 | 韩日一区二区三区 | 99久久婷婷国产综合亚洲 |