参考代码:
public void reorder1() { Scanner sc = new Scanner(System.in); int n = sc.nextInt(); int[] arr = new int[n]; for (int i = 0; i < n; i++) { arr[i] = sc.nextInt(); } Arrays.sort(arr); int count = 1; String str = arr[0]+" "; for (int i = 1; i < n; i++) { if (arr[i] != arr[i - 1]){ str += arr[i]+" "; count++; } } System.out.println(count); System.out.println(str.substring(0,str.length()-1)); } public void reorder2() { Scanner sc = new Scanner(System.in); while(sc.hasNext()){ Set<Integer> set = new TreeSet<>(); int n = sc.nextInt(); while(n-- > 0){ set.add(sc.nextInt()); } StringBuffer sb = new StringBuffer(); Iterator<Integer> iterator = set.iterator(); while(iterator.hasNext()){ sb.append(iterator.next() + " "); } //打印结果 System.out.println(set.size()); System.out.println(sb.substring(0, sb.length()-1)); } } public void reorder3() { Scanner scanner = new Scanner(System.in); int n = scanner.nextInt(); int[] arr = new int[n]; for (int i = 0; i < n; i++) { arr[i] = scanner.nextInt(); } String b = ""; for (int i = 0; i < arr.length; i++) { boolean flag = true; for (int j = i - 1; j >= 0; j--) { if (arr[i] == arr[j]) { flag = false; } } if (flag == true) { b += arr[i] + " "; } } String[] bs = b.split(" "); int[] p = new int[bs.length]; for (int i = 0; i < bs.length; i++) { p[i] = Integer.parseInt(bs[i]); } Arrays.sort(p); System.out.println(p.length); for (int i = 0; i < p.length; i++) { System.out.print(p[i] + " "); } }
0.0分
0 人评分
C二级辅导-分段函数 (C语言代码)浏览:583 |
C语言程序设计教程(第三版)课后习题8.3 (C语言代码)浏览:677 |
C语言程序设计教程(第三版)课后习题10.3 (C语言代码)浏览:711 |
数列 (C++代码)浏览:707 |
C语言训练-字符串正反连接 (C语言代码)浏览:664 |
这可能是一个假的冒泡法浏览:1071 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:909 |
妹子杀手的故事 (C语言代码)浏览:1298 |
C语言训练-求1+2!+3!+...+N!的和 (C语言代码)浏览:822 |
WU-陶陶摘苹果2 (C++代码)浏览:1018 |