Arrays类、冒泡排序、稀疏数组

Arrays类

package base;

import java.util.Arrays;

/**
 * Arrays类
 */
public class ArraysTest {
    public static void main(String[] args) {
        int [] a = {1,2,3,4543,3,422,45,24,33};
        System.out.println("数组地址值为:"+Arrays.asList(a));
        System.out.println("数组具体值为:"+Arrays.toString(a));
        Arrays.sort(a);
        System.out.println("排序后的具体值为:"+Arrays.toString(a));
        System.out.println("打印自定义的Arrays类toString方法,结果如下:");
        printA(a);
        System.out.println();
        //Arrays.fill(a,0);//指定元素被填充
        //System.out.println(Arrays.toString(a));
        Arrays.fill(a,2,4,0);
        System.out.println("对应位置填充0后得到的数组为:"+Arrays.toString(a));
    }

    /**
     * 手写to_string方法
     * @param a
     */
    public static void printA(int [] a){
        for (int i = 0; i <a.length ; i++) {
            if(i==0){
                System.out.printf("[");
            }
            if(i==a.length-1){
                System.out.print(a[i]+"] ");
            }else{
                System.out.print(a[i]+", ");
            }
        }
    }
}

输出结果如下所示:
数组地址值为:[[I@4554617c]
数组具体值为:[1, 2, 3, 4543, 3, 422, 45, 24, 33]
排序后的具体值为:[1, 2, 3, 3, 24, 33, 45, 422, 4543]
打印自定义的Arrays类toString方法,结果如下:
[1, 2, 3, 3, 24, 33, 45, 422, 4543]
对应位置填充0后得到的数组为:[1, 2, 0, 0, 24, 33, 45, 422, 4543]

冒泡排序

package base;

import java.util.Arrays;

/**
 *
 * 冒泡排序
 *
 * 1.在数组中,比较相邻的两个元素,要是第一个元素比第二个元素大,就交换位置
 * 2.每次比较都会产生一个较大和较小的数字
 * 3.下一轮就可以少一次排序
 * 4.依次循环,直到结束
 */
public class Demo04 {
    public static void main(String[] args) {
        int [] array = {1,223,23,45,3,24,533,3};
        System.out.println(Arrays.toString(sort(array)));
    }

    public static int [] sort(int [] array){
        int temp = 0;
        //外层循环:判断我们要走多少次
        for (int i = 0; i <array.length-1 ; i++) {
            //内层循环:比较判断两个数,如果第一个数比第二个数大,就交换位置
            for (int j = 0; j <array.length-1-i ; j++) {
                temp = array[j];
                if(array[j+1]>array[j]){
                    temp = array[j];
                    array[j] = array[j+1];
                    array[j+1] = temp;
                }
            }
        }
        return array;
    }
}

输出结果如下所示:
[533, 223, 45, 24, 23, 3, 3, 1]

稀疏数组

当一个数组大部分元素为0,或者为同一值的数组时,可以用稀疏数组来保存该数组,起到压缩的作用;

稀疏数组的处理方式是:记录数组一共有几行几列,有多少个不同值;

把具有不同值的元素和行列及值记录在小规模的数组中,从而缩小程序的规模;

需求:编写五子棋游戏中,有存盘退出和续上盘的功能;

​ 因为该二维数组的很多默认值为0,因此记录了很多没有意义的数据;

​ 解决:稀疏数组;

package base;

import java.util.Arrays;

/**
 * 稀疏数组
 */
public class Demo05 {
    public static void main(String[] args) {
        //创建一个二维数组,11行11列,白棋为0,黑棋为1
        int [][] array1 = new int[11][11];
        array1[1][2] = 1;
        array1[2][3] = 2;

        System.out.println("原始数组为:");

        for (int [] ints : array1) {
            for (int anInt: ints) {
                System.out.print(anInt + "\t");
            }
            System.out.println();
        }

        //创建为稀疏数组
        //保存有效数字
        int sum = 0;
        for (int i = 0; i <11 ; i++) {
            for (int j = 0; j <11 ; j++) {
                if(array1[i][j]!=0){
                    sum++;
                }
            }
        }
        System.out.println("有效值个数为:"+sum);
        System.out.println("-----------------");

        //创建一个稀疏数组
        int [][] array2 = new int [sum+1][3];
        array2[0][0] = 11;
        array2[0][1] = 11;
        array2[0][2] = sum;

        //便利二维数组,把非0的值存到此数组中
        int count = 0;
        for (int i = 0; i <array1.length ; i++) {
            for (int j = 0; j <array1[i].length ; j++) {
                if(array1[i][j]!=0){
                    count ++;
                    array2[count][0]=i;
                    array2[count][1]=j;
                    array2[count][2]=array1[i][j];
                }
            }
        }

        System.out.println("输出稀疏数组:");

        for (int i = 0; i < array2.length ; i++) {
            System.out.println(array2[i][0]+"\t"+
                    array2[i][1]+"\t"+
                    array2[i][2]);
        }

        System.out.println("-----------------");
        //1.还原稀疏数组
        int[][]array3 = new int [array2[0][0]][array2[0][1]];
        //2.给其中元素还原他的值
        for (int i = 1; i < array2.length ; i++) {
            array3[array2[i][0]][array2[i][1]] = array2[i][2];
        }
        //2.打印
        System.out.println("还原的数组为:");
        for (int [] ints : array3) {
            for (int anInt: ints) {
                System.out.print(anInt + "\t");
            }
            System.out.println();
        }
    }
}

输出结果如下所示:

原始数组为:
0 0 0 0 0 0 0 0 0 0 0
0 0 1 0 0 0 0 0 0 0 0
0 0 0 2 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0

有效值个数为:2

输出稀疏数组:
11 11 2
1 2 1
2 3 2

还原的数组为:
0 0 0 0 0 0 0 0 0 0 0
0 0 1 0 0 0 0 0 0 0 0
0 0 0 2 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0

posted @ 2021-12-09 16:47  Dawn_006  阅读(30)  评论(0)    收藏  举报