搜尋

首頁  >  問答  >  主體

關於python統計一個整數列表中不同數值種類數的問題。

下面這段程式碼中,kind_num用來統計那個整數列表中有幾個不同數值的整數。

class Solution(object):
    def distributeCandies(self, candies):
        """
        :type candies: List[int]
        :rtype: int
        """
        loc = len(candies)
        mol = loc % 2
        if 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 = 0
        sis_num = loc / 2
        for candy in candies:
            kind_num += 1
            while True:
                try:
                    candies.remove(candy)
                    print candies
                except ValueError:
                    break
        if kind_num > sis_num:
            return sis_num
        elif kind_num < sis_num:
            return kind_num
        else:
            return sis_num


s = Solution()

print s.distributeCandies([1,1,2,2,3,3])

但是第二個for循環,沒有取完candies裡面的值就提前退出了,這是為什麼? ? ?

#
大家讲道理大家讲道理2770 天前967

全部回覆(3)我來回復

  • 曾经蜡笔没有小新

    曾经蜡笔没有小新2017-06-22 11:54:27

    在循環裡不要去remove

    如果你只是想實現統計不同種類的值

    #统计出现次数
    lst = [1,1,2,2,3,3,4,4,5,6]
    print len(set(lst))
    
    #统计每种各出现几次
    from collections import Counter
    print dict(Counter(lst))
    

    回覆
    0
  • 天蓬老师

    天蓬老师2017-06-22 11:54:27

    candies.remove(candy) 第一次執行 Ok, candy被remove; 由於while (True), 在同一次For 循環中 會無限remove 這個candy,但是這個candy 已經在第一次被移除了。所以break.

    回覆
    0
  • phpcn_u1582

    phpcn_u15822017-06-22 11:54:27

    雷雷

    回覆
    0
  • 取消回覆