• 十七、Java中数组常见的几种排序方法!


    转载自:https://www.cnblogs.com/bekeyuan123/p/6891875.html


    数组的定义:

            // 3种定义方式
            int[] arr = new int[5];
    
            int[] arr1 = {1,2,3,4,5};
    
            int[] nums = new int[]{1, 2, 3};
            
            long[] arr2 = new long[6];
            
            String[] strs = new String[5];
            
            // 数组可以存储引用类型
            Person[] ps = new Person[5];

    数组的操作:        int[] arr = {45, 34, 53, 43};

    // 默认升序排序
            Arrays.sort(arr);
            System.out.println(Arrays.toString(arr));
            
            // 二分搜索法(使用之前需要先使用Arrays.sort()排序),如果没有找到数字,返回为负数;返回正数,代表数字在数组中的索引
            int i = Arrays.binarySearch(arr, 34);
            System.out.println(i);
         // Arrays.copyOf()底层实现是System.arraycopy();
    int[] newArr = Arrays.copyOf(arr, 7);

         // copyOfRange()方法第三个参数是索引值,包左不包右
    int[] newArr1 = Arrays.copyOfRange(arr, 1, 3); System.out.println(Arrays.toString(newArr)); System.out.println(Arrays.toString(newArr1));
         // binarySearch()方法第三个参数是索引值,包左不包右
    int j = Arrays.binarySearch(arr, 1, 3, 34); System.out.println(j);

    冒泡排序:

           int[] arr = {23,12,48,56,45};
          int temp = -1;
            for(int i=0;i<arr.length;i++) {
                for(int j=i+1;j<arr.length;j++) {
                    if(arr[i]>arr[j]) {
                        temp = arr[i];
                        arr[i] = arr[j];
                        arr[j] = temp;
                    }
                }
            }
            System.out.println(Arrays.toString(arr));

    直接选择排序:

           int[] arr = {23,12,48,56,45};
         for(int i=0;i<arr.length;i++) {
                int tem = i;
           // 每一趟的比较都把最小的一个数字的索引找到
    for(int j=i;j<arr.length;j++) { if(arr[j] < arr[tem]) { tem = j; } } int temp1 = arr[i]; arr[i] = arr[tem]; arr[tem] = temp1; } System.out.println(Arrays.toString(arr));

    反转排序:

            int[] arr = {23,12,48,56,45};
        for(int i=0;i<arr.length / 2;i++) {
                int temp = arr[i];
                arr[i] = arr[arr.length-i-1];
                arr[arr.length-i-1] = temp;
            }
            System.out.println(Arrays.toString(arr))
    每天进步一点点 个人意见,仅供参考
  • 相关阅读:
    2019.4.26 周五 阴转小雨
    2019.4.25 周四 阴有小雨
    2019.4.24 周三 阴
    2019.4.23 周二 阴
    2019.4.22 周一 阴转小雨
    oracle优化(一)
    Opencv-Python学习笔记(二)
    Opencv-Python学习笔记(一)
    XtraGrid实现checkbox全选功能
    XtraGrid中checkbox状态设置
  • 原文地址:https://www.cnblogs.com/mason117/p/10727492.html
Copyright © 2020-2023  润新知