50. 随机数排序

50. 随机数排序

题目描述

生成 N 个 1 到 500 的随机数,你需要删除掉其中重复的数字,即相同的数字只保留一个,把其余相同的数字去掉,然后再把这些数从小到大进行输出。

输入描述

第一行先输入随机整数的个数 N 。 接下来一行包含 N 整数,代表生成的随机数。

输出描述

输出为单独一行,为去重排序过的数组,每个数字后都有一个空格。

输入示例

3

2 2 1

输出示例

1 2

提示信息

数据范围:

1 <= N <= 10^9

1 <= 随机数 <= 500

实现代码(Python):

python 复制代码
import sys 

def main():
    lines=sys.stdin.read().splitlines()
    idx=0
    n=int(lines[idx])
    idx+=1
    nums=list(map(int,lines[idx].split()))
    #print(nums)
    nums_set=[0]*501
    for i in range(n):
        nums_set[nums[i]]+=1
    #print(nums_set)

    res=[]
    for i in range(1,501):
        if nums_set[i]!=0:
            res.append(i)
    s=[str(x) for x in res]
    print(' '.join(s))

if __name__=="__main__":
    main()
        

分析

哈希表优势:去重操作 O (1) 时间复杂度

本题也可使用:集合(set),其是 Python 中最简洁的哈希表实现,add() 操作时间复杂度 O (1),遍历 N 个数的时间复杂度 O (N);

相关推荐
小白兔奶糖ovo10 分钟前
【Leetcode】231. 2的幂
linux·算法·leetcode
xiaoxiaoxiaolll13 分钟前
《Light: Science & Applications》合并BIC实现80倍阈值单模运行:超紧凑光子晶体激光器新突破
人工智能·算法·机器学习
安替-AnTi17 分钟前
厚朴 APK 搜索接口分析
python·apk·解析·taobao
Peter·Pan爱编程19 分钟前
14. Lambda 表达式:随手可写的函数对象
c++·算法·ai编程
-To be number.wan19 分钟前
算法日记 | 暴力枚举
学习·算法
s_w.h35 分钟前
【 linux 】动静态库的制作
linux·运维·服务器·算法·bash
山川湖海40 分钟前
AI时代快速学编程语言的陷阱(以Python为例)
大数据·人工智能·python
H Journey44 分钟前
Supervisor 进程管理工具介绍
python·supervisor·linux 运维
过期动态1 小时前
【LeetCode 热题 100】接雨水
java·数据结构·算法·leetcode·职场和发展
春日见1 小时前
5分钟入门强化学习之动态规划算法与实现
大数据·人工智能·python·算法·机器学习·计算机视觉