题解 | #明明的随机数#
明明的随机数
https://www.nowcoder.com/practice/3245215fffb84b7b81285493eae92ff0
import java.util.Scanner; // 都保存到数组num,排序,排好之后当前值和上一个不相等,就输出 public class Main { public static void main(String[] args) { Scanner in = new Scanner(System.in); int n = in.nextInt(); int[] num = new int[n]; int i = 0; for(;i<n;i++){ num[i] = in.nextInt(); } int tmp = 0; for(i=0;i<n-1;i++) for(int j=0;j<n-i-1;j++){ if(num[j]>num[j+1]){ tmp = num[j]; num[j]=num[j+1]; num[j+1]=tmp; } //sqrt(num[j],num[j+1]); } for(i=0;i<n;i++) if(i==0) System.out.println(num[i]); else if(num[i]!=num[i-1]) System.out.println(num[i]); } public static void sqrt(int a,int b){ int tmp = a; a=b; b=tmp; } /* 在 Java 中,函数的参数传递是按值传递(pass-by-value)的,也就是说,在函数调用时,传递给函数的是参数值的副本,而不是参数值本身。因此,在 sqrt 函数中交换 a 和 b 的值并不会影响 main 函数中 num 数组中元素的顺序。 为了交换 a 和 b 的值,我们可以将 sqrt 函数的参数改为数组索引,然后在函数中交换 num[a] 和 num[b] 的值。这样,函数调用会改变 num 数组中元素的值,从而达到交换元素位置的目的。 */ }