0
点赞
收藏
分享

微信扫一扫

《华为机试》刷题之HJ3 明明的随机数

鱼满舱 2022-02-07 阅读 54

一、题目

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

数据范围: 1 ≤ n ≤ 1000 1\le n\le 1000 1n1000,输入的数字大小满足 1 ≤ v a l ≤ 500 1\le val\le 500 1val500

输入描述:
注意:输入可能有多组数据(用于不同的调查)。每组数据都包括多行,第一行先输入随机整数的个数 N ,接下来的 N 行再输入相应个数的整数。具体格式请看下面的"示例"。

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

二、示例

输入:3
     2
     2
     1
     11
     10
     20
     40
     32
     67
     40
     20
     89
     300
     400
     15
输出:1
     2
     10
     15
     20
     32
     40
     67
     89
     300
     400
说明:示例1包含了两个小样例!! 
      输入解释:第一个数字是3,也即这个小样例的N=3,说明用计算机生成了3个1到1000之间的随机整数,
      接下来每行一个随机数字,共3行,也即这3个随机数字为:
		2
		2
		1
      所以第一个小样例的输出为:
		1
		2
      第二个小样例的第一个数字为11,也即...(类似上面的解释)...
      所以第二个小样例的输出为:
		10
		15
		20
		32
		40
		67
		89
		300
		400   

三、代码

while True:
    try:
        N = input()
        temp = []
        for i in range(int(N)):
            temp.append(int(input()))
        result = set(temp)
        for i in sorted(result):
            print(i)
    except:
        break

四、算法说明

首先获得数字的个数N
人后将所有的数字存入列表Temp
set()函数将Temp中的元素进行去重操作;
sorted()函数将Temp中的元素进行排序操作,然后按行打印。

胡萝卜

我不知道将去向何方,但我已在路上!
时光匆匆,虽未曾谋面,却相遇于斯,实在是莫大的缘分,感谢您的到访 !
举报

相关推荐

0 条评论