关于传入列表出现元素次数排序题目的一点心得

首先把题目贴出来:

        给定一个只包含正整数且非空的数组(如[1,6,7,4,4,5,4,5,4,5,5,6,7,8,5,6,7,3,4,2,2,1,4,8,9,4,5,6]),返回该数组中重复次数最多的前N个数字(返回结果按重复次数从多到少降序排列,N不存在取值非法的情况),请用熟悉的语言实现该需求 

然后是代码:

class Homework():
    def Array(self):
        input_array = []
        while True:
            list = input("请输入你要记录的数组数字,回车确定,'Q'退出:\n")
            if list.isdigit() == True:
                input_array.append(list)
                print(input_array)
            elif list == "Q":
                return input_array
            else:
                print("输入错误,请重新输入!")
                continue
    def Frequency(self,input_array=[]):
        print(input_array)
        frequency = {}
        for i in range(len(input_array)):
            key  = input_array[i]
            num = input_array.count(key)
            dict_1 = { key : num }
            frequency.update(dict_1)
        return frequency
    def Sort(self,frequency):
        d = sorted(frequency.items(),key=lambda item:item[1],reverse=True)
        print("按照出现次数从多到少排序情况如下:\n")
        for i in range(len(d)):
            print('{}出现{}次'.format(d[i][0],d[i][1]))
if __name__ == '__main__':
    input_array = Homework().Array()
    frequency = Homework().Frequency(input_array)
    Homework().Sort(frequency)

第一点:传入字典或者列表的参数最好为(self,list)或者(self,dict),不然会冒出奇怪的参数,比如object at 0x0000028FC5B70588,这个参数莫名其妙的出现,卡了我很久 ,然后加了self才把这个参数分离出去

第二点:字典经过sorted排序之后的类型就不再是dict而是list了,最开始我以为排序后依旧是字典,用字典的取执法反而报错,加了断点才发现排序后的类型变了,以后要注意

第三点:如果想要sorted排序后依旧是字典,可以在最外层加dict()方法,例如 

d = dict(sorted(frequency.items(),key=lambda item:item[1],reverse=True))

就行了,不过还是之前的哪句话,尽量避免无意义的参数类型转换,所以最后还是按照列表类型取值

总之,收获还是蛮多的

posted @ 2019-02-24 11:13  桂木  阅读(193)  评论(0编辑  收藏  举报