1121: 明明的随机数
2017-05-18 09:40
513 查看
题目
Description明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了N个1到1000之间的随机整数(N≤100),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不同的学生的学号。然后再把这些数从小到大排序,按照排好的顺序去找同学做调查。请你协助明明完成“去重”与“排序”的工作。
Input
有2行,第1行为1个正整数,表示所生成的随机数的个数:
N
第2行有N个用空格隔开的正整数,为所产生的随机数。
Output
也是2行,第1行为1个正整数M,表示不相同的随机数的个数。第2行为M个用空格隔开的正整数,为从小到大排好序的不相同的随机数。
Sample Input
10
20 40 32 67 40 20 89 300 400 15
Sample Output
8
15 20 32 40 67 89 300 400
代码块
import java.util.Arrays;//数组jdk包 import java.util.Scanner;//输入jdk包 public class J1121 { public static void main(String[] args) { Scanner cn = new Scanner(System.in);//输入流 int n = cn.nextInt(); int[] num = new int ; for (int i = 0; i < n; i++) { num[i] = cn.nextInt(); } for (int i = 0; i < n-1; i++) {//如果有重复将其多余的变为-1 for (int j = i+1; j < n; j++) { if (num[j] < 0) continue; else { if (num[i] == num[j]) num[j] = -1; } } } Arrays.sort(num);//进行数组排序 int i = 0; while (num[i] < 0) {//先找出第一个大于0 的整数 i++; } System.out.println(n-i);//输出,去掉重复个数之后,整数的个数 System.out.print(num[i]);//输出第一个大于0 的整数 for (int j = i+1; j < n; j++) {//依次输出后面的整数 if (num[j] > 0) { System.out.print(" " + num[j]); } } } }