返回顶部

Java数组操作-数组排列分享

[复制链接]
芬芳撩人Lv.2 显示全部楼层 发表于 2021-10-25 13:07:58 |阅读模式 打印 上一主题 下一主题
  对数组进行排序是程序中非常基本的需求。常用的排序算法有冒泡排序、插入排序和快速排序等。

(内容来源于公开网络,若涉及侵权联系尽快删除!)


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

  //冒泡排序
[Java] 纯文本查看 复制代码
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));
    }
}

  

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

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

[Java] 纯文本查看 复制代码
int x = 1;
int y = 2;

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


  正确的写法是:

[Java] 纯文本查看 复制代码
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()就可以排序:

  //排序

[Java] 纯文本查看 复制代码
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));
    }
}
  

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

[Java] 纯文本查看 复制代码
int[] ns = { 9, 3, 6, 5 };


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

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

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

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

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

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

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

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

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

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

[Java] 纯文本查看 复制代码
String[] ns = { "banana", "apple", "pear" };

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

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

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

  ││▼▼

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

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

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

  │▲

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

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

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

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

  ││▼▼

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

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

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

  │▲

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

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

  练习

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

[Java] 纯文本查看 复制代码
// 降序排序
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));

[Java] 纯文本查看 复制代码
 // TODO:


[Java] 纯文本查看 复制代码
   // 排序后:
        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("测试失败");
        }
    }
}


  从下载练习:降序排序练习(推荐使用IDE练习插件快速下载)

  小结

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

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

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

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

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

(免责声明:内容来源于公开网络,若涉及侵权联系尽快删除!)

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

达内教育:成立于2002年。致力于面向IT互联网行业,培养软件开发工程师、测试工程师、系统管理员、智能硬件工程师、UI设计师、网络营销、会计等职场人才 达内使命:缔造年轻人的中国梦、缔造达内员工的中国梦 达内愿景:做管理一流的教育公司
  • 商务合作

  • 微信公众号

  • Powered by Discuz! X3.4 | Copyright © 2002-2021, 达内教育 Tedu.cn
  • 京ICP备08000853号-56 |网站地图 | 京公网安备 11010802029508号