python使用内置函数方法和桶排序方法实现随机数去重、排序输出

320 篇文章 88 订阅
151 篇文章 4 订阅

    在python中对于列中的数据的排序、去重等操作都有已经封装的很好的内置函数了,效率也是不错的,今天使用内置函数和桶排序的方法来实现对输入的随机数数组进行排序输出,问题很简单,做法也很简单,如果想要看桶排序的思想和实现可以看我之前的博文,有几乎所有常用的排序算法的实现,当然这些也都是面试的时候几乎都会问几句的东西,好了具体实现如下:

#!usr/bin/env python
#encoding:utf-8

'''
__Author__:沂水寒城
功能:输入:多行数据,第一行为总输入行数接下来为每行数字
      输出:经过排序去重后分行输出的数据
'''

def func_test1():
    '''
    最基础的做法,但是疑惑的是在newcoder上从来都是通过率为0
    '''
    n=int(raw_input())
    num_list=[]
    new_list=[]
    for i in range(n):
        num_list.append(int(raw_input()))
    new_list=sorted(list(set(num_list)))
    for one in new_list:
        print one


def func_test2():
    '''
    借鉴桶排序的思想,空间换时间,效率很高
    '''
    n=int(raw_input())
    num_list=[0]*1001
    out_list=[]
    for i in range(n):
        one_num=int(raw_input())
        num_list[one_num]=one_num
    for one in num_list:
        if one:
            print one


if __name__ == '__main__':
    func_test1()
    print '**************************************************************************************************'
    func_test2()

结果如下:

10
12
56
7
9
45
23
12
45
56
34
7
9
12
23
34
45
56
**************************************************************************************************
15
23
56
89
34
12
5
8
9
5
34
12
45
56
67
34
5
8
9
12
23
34
45
56
67
89


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Together_CZ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值