明明的随机数
##明明生成了N个1到500的随机数。请你删去其中重复的数字,即相同的数字质保留一个,把其余数字按从小到大的顺序输出。
数据范围:1<=n<=1000,输入的数字大小满足1<=val<=500
输入描述:
第一行先输入随机整数的个数 N 。 接下来的 N 行每行输入一个整数,代表明明生成的随机数。 具体格式可以参考下面的"示例"。
输出描述:
输出多行,表示输入数据处理后的结果
示例1
输入:
3
2
2
1
复制
输出:
1
2
复制
说明:
输入解释:
第一个数字是3,也即这个小样例的N=3,说明用计算机生成了3个1到500之间的随机整数,接下来每行一个随机数字,共3行,也即这3个随机数字为:
2
2
1
所以样例的输出为:
1
2
//简单思路:创建一个数组arr[1001]
//给arr[i]的值+1;
//然后输出arr[i]的值大于等于出数值的所有元素索引
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int N = in.nextInt();
int[] arr = new int[1001];
int num =0;
while(N>0){
num = in.nextInt();
N--;
arr[num]++;
}
for (int i = 0; i < arr.length ; i++) {
if(arr[i]>0){
System.out.println(i);
}
}
}
以上是个人的思路,如有不一样更简单的解法,欢迎探讨。