python三维数组排序_数组排序

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

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

// 冒泡排序

----

import java.util.Arrays;

public class Main {

public static void main(String[] args) {

int[] ns = { 28, 12, 89, 73, 65, 18, 96, 50, 8, 36 };

// 排序前:

System.out.println(Arrays.toString(ns));

for (int i = 0; i < ns.length - 1; i++) {

for (int j = 0; j < ns.length - i - 1; j++) {

if (ns[j] > ns[j+1]) {

// 交换ns[j]和ns[j+1]:

int tmp = ns[j];

ns[j] = ns[j+1];

ns[j+1] = tmp;

}

}

}

// 排序后:

System.out.println(Arrays.toString(ns));

}

}

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

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

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[] ns = { 28, 12, 89, 73, 65, 18, 96, 50, 8, 36 };

Arrays.sort(ns);

System.out.println(Arrays.toString(ns));

}

}

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

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

在内存中,这个整型数组表示如下:

┌───┬───┬───┬───┐

ns───>│ 9 │ 3 │ 6 │ 5 │

└───┴───┴───┴───┘

当我们调用Arrays.sort(ns);后,这个整型数组在内存中变为:

┌───┬───┬───┬───┐

ns───>│ 3 │ 5 │ 6 │ 9 │

└───┴───┴───┴───┘

即变量ns指向的数组内容已经被改变了。

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

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

排序前,这个数组在内存中表示如下:

┌──────────────────────────────────┐

┌───┼──────────────────────┐ │

│ │ ▼ ▼

┌───┬─┴─┬─┴─┬───┬────────┬───┬───────┬───┬──────┬───┐

ns ─────>│░░░│░░░│░░░│ │"banana"│ │"apple"│ │"pear"│ │

└─┬─┴───┴───┴───┴────────┴───┴───────┴───┴──────┴───┘

│ ▲

└─────────────────┘

调用Arrays.sort(ns);排序后,这个数组在内存中表示如下:

┌──────────────────────────────────┐

┌───┼──────────┐ │

│ │ ▼ ▼

┌───┬─┴─┬─┴─┬───┬────────┬───┬───────┬───┬──────┬───┐

ns ─────>│░░░│░░░│░░░│ │"banana"│ │"apple"│ │"pear"│ │

└─┬─┴───┴───┴───┴────────┴───┴───────┴───┴──────┴───┘

│ ▲

└──────────────────────────────┘

原来的3个字符串在内存中均没有任何变化,但是ns数组的每个元素指向变化了。

练习

请思考如何实现对数组进行降序排序:

// 降序排序

import java.util.Arrays;

public class Main {

public static void main(String[] args) {

int[] ns = { 28, 12, 89, 73, 65, 18, 96, 50, 8, 36 };

// 排序前:

System.out.println(Arrays.toString(ns));

----

// TODO:

----

// 排序后:

System.out.println(Arrays.toString(ns));

if (Arrays.toString(ns).equals("[96, 89, 73, 65, 50, 36, 28, 18, 12, 8]")) {

System.out.println("测试成功");

} else {

System.out.println("测试失败");

}

}

}

小结

常用的排序算法有冒泡排序、插入排序和快速排序等;

冒泡排序使用两层for循环实现排序;

交换两个变量的值需要借助一个临时变量。

可以直接使用Java标准库提供的Arrays.sort()进行排序;

对数组排序会直接修改数组本身。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值