关于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. docker start -a dockername 老是卡住,什么情况?2. python运行后没有任何反馈要怎么排查3. java内存模型的happens-before语义顺序问题4. objective-c - iOS开发使用什么对html进行代码高亮5. java - 并发操作下关于队列的疑问?6. :not 选择器 无效果 原因何在?7. linux - 阿里云服务器(centos)中svn同步web目录的问题?8. android - RxJava 中有根据条件执行不同函数的操作符吗?9. 从事游戏服务端开发(Java),需要具备哪些技术???10. 编程 - java 为什么没有静态方法接口,有没有哪门语言有静态方法接口。
