关于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. dockerfile - 为什么docker容器启动不了?2. docker - 各位电脑上有多少个容器啊?容器一多,自己都搞混了,咋办呢?3. golang - 用IDE看docker源码时的小问题4. docker gitlab 如何git clone?5. nignx - docker内nginx 80端口被占用6. docker安装后出现Cannot connect to the Docker daemon.7. javascript - weex和node,js到底是怎样一个关系呢?8. javascript - 修改表单多选项时和后台同事配合的问题。9. Python Selenium WebDriver如何刷新当前页面10. 我在centos容器里安装docker,也就是在容器里安装容器,报错了?

网公网安备