题解 | #明明的随机数#

明明的随机数

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 数组中元素的值,从而达到交换元素位置的目的。
    */
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
08-15 16:48
想要一个AK:问题很多加微信私聊 (一个赞十道算法题,我看看有多少)
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务