Java的数组排序

冒泡排序

对数组进行排序是程序中非常基本的需求。常用的排序算法有冒泡排序、插入排序和快速排序等。

我们来看一下如何使用冒泡排序算法对一个整型数组从小到大进行排序:

import java.util.Arrays;

public class Main {
    public static void main(String[] args) {
        int[] n = { 28, 12, 89, 73, 65, 18, 96, 50, 8, 36 };
        // 排序前:
        System.out.println(Arrays.toString(n));
        for (int i = 0; i < n.length - 1; i++) {
            for (int j = 0; j < n.length - i - 1; j++) {
                if (n[j] > n[j+1]) {
                    // 交换n[j]和n[j+1]:
                    int temp = n[j];
                    n[j] = n[j+1];
                    n[j+1] = temp;
                }
            }
        }
        // 排序后:
        System.out.println(Arrays.toString(n));
    }
}

冒泡排序的特点是,每一轮循环后,最大的一个数被交换到末尾,因此,下一轮循环就可以“刨除”最后的数,每一轮循环都比上一轮循环的结束位置靠前一位。

另外,注意到交换两个变量的值必须借助一个临时变量。
像这么写是错误的:

int x = 1;
int y = 2;

x = y; // x现在是2
y = x; // y现在还是2

正确的写法是:

int x = 1;
int y = 2;

int t = x; // 把x的值保存在临时变量t中, t现在是1
x = y; // x现在是2
y = t; // y现在是t的值1

实际上,Java的标准库已经内置了排序功能,我们只需要调用JDK提供的 Arrays.sort() 就可以排序:

import java.util.Arrays;

public class Main {
    public static void main(String[] args) {
        int[] n = { 28, 12, 89, 73, 65, 18, 96, 50, 8, 36 };
        Arrays.sort(n);
        System.out.println(Arrays.toString(n));
    }
}

必须注意,对数组排序实际上修改了数组本身。例如,排序前的数组是:

int[] n = { 9, 3, 6, 5 };

在内存中,这个整型数组表示如下:
在这里插入图片描述
当我们调用 Arrays.sort(n); 后,这个整型数组在内存中变为:
在这里插入图片描述
即变量n指向的数组内容已经被改变了。

字符串数组排序

如果对一个字符串数组进行排序,例如:

String[] n = { "banana", "apple", "pear" };

排序前,这个数组在内存中表示如下:
在这里插入图片描述
调用 Arrays.sort(n); 排序后,这个数组在内存中表示如下:
在这里插入图片描述
原来的3个字符串在内存中均没有任何变化,但是 n数组 的每个元素指向变化了。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值