明明的随机数(Python,华为机试)

题目描述

明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了N个1到1000之间的随机整数(N≤1000),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不同的学生的学号。然后再把这些数从小到大排序,按照排好的顺序去找同学做调查。请你协助明明完成“去重”与“排序”的工作(同一个测试用例里可能会有多组数据,希望大家能正确处理)。

输入:输入多行,先输入随机整数的个数,再输入相应个数的整数。

输出:返回多行,处理后的结果。

 

输入示例

5
23
46
32
23
6

输出示例

6
23
32
46

题目分析

抛开花哨的题目描述,这道题的题意就是对一个整型的数字序列排序,但是要删掉重复的数字。数字序列的输入多少取决于自己的输入。首先想到可以使用set()函数对序列进行“去重”,然后将去重后的序列用sort()函数排序,最终分行输出。

 

测试用例:

输入的第一个数(决定输入总数的数字)小于或等于0

 

代码:

amount = int(input())
numbers = []

if amount <= 0:
    exit()

for i in range(amount):
    number = int(input())
    numbers.append(number)

numbers_set = set(numbers)
result = []

for element in numbers_set:
    result.append(element)

result.sort()
for element in result:
    print(element)

注意事项:

先进行set()函数去重,在进行sort()函数排序。顺序不能变。因为set函数将列表转化为集合后是无序的,会将转换之前的序列打乱。

 

传送门:

1. exit()函数:

https://blog.csdn.net/TCatTime/article/details/82080093

2.  set()函数

https://blog.csdn.net/TCatTime/article/details/82312600

猜你喜欢

转载自blog.csdn.net/TCatTime/article/details/82291910