關于python統計一個整數列表中不同數值種類數的問題。
問題描述
下面這段代碼中,kind_num用于統計那個整數列表中有幾種不同數值的整數。
class Solution(object): def distributeCandies(self, candies):''':type candies: List[int]:rtype: int'''loc = len(candies)mol = loc % 2if not (2 <= loc <= 10000) or mol != 0: return ’wrong length of array’for num in candies: if not (-10000 <= num <= 10000):return ’wrong element in array’kind_num = 0sis_num = loc / 2for candy in candies: kind_num += 1 while True:try: candies.remove(candy) print candiesexcept ValueError: breakif kind_num > sis_num: return sis_numelif kind_num < sis_num: return kind_numelse: return sis_nums = Solution()print s.distributeCandies([1,1,2,2,3,3])
但是第二個for循環,沒有取完candies里面的值就提前退出了,這是為什么???
問題解答
回答1:在循環里不要去remove
如果你僅僅是想實現統計不同種類的值
#統計出現次數lst = [1,1,2,2,3,3,4,4,5,6]print len(set(lst))#統計每種各出現幾次from collections import Counterprint dict(Counter(lst))回答2:
candies.remove(candy) 第一次執行 Ok, candy被remove; 由于while (True), 在同一次For 循環中 會無限remove 這個candy,但是這個candy 已經在第一次被移除了。所以break.
回答3:from collections import defaultdictd = defaultdict(int)for item in your_list: d[item] += 1 print d
相關文章:
1. css3 - 求教CSS圖標庫的寫法,也就是先做雪碧圖,然后寫一個css表,用的時候直接用class就可以了2. 百度地圖api - Android百度地圖SDK,MapView上層按鈕可見卻不可觸,怎么解決?3. html - 前端大牛都頂一下!CSS鼠標樣式問題,如圖所示4. javascript - es6擴展運算符...的問題5. 網頁爬蟲 - python爬蟲用BeautifulSoup爬取<s>元素并寫入字典,但某些div下沒有這一元素,導致自動寫入下一條,如何解決?6. node.js - 在nodejs環境中如何配置webhook以實現hexo博客的自動更新?7. html5 - canvas中的mousedrag事件,為什么鼠標拖出canvas,然后再次移入canvas,drag事件還觸發8. javascript - jquery怎么給select option一個點擊時觸發的事件,如圖 如果選擇自定義觸發一個時間?9. 新入手layuiadmin,部署到tp中。想用php自已寫一個后臺管理系統。10. mysql 獲取時間函數unix_timestamp 問題?
