zoukankan      html  css  js  c++  java
  • java入门 (六) 数组(二)

    java入门(六)数组(二)

    1. 数组的使用
    2. 多维数组(二维数组)
    3. Arrays类讲解
    4. 冒泡排序
    5. 稀疏数组

    数组的使用

    public class ArrayDemo04 {
        public static void main(String[] args) {
            int[] arrays = {1,2,3,4,5};
            //jdk1.5,没有下标
    //        for (int array : arrays) {
    //            System.out.println(array);
    //        }
            int[] reverse = reverse(arrays);
            printArray(reverse);
        }
    
    
    
        //反转数组
        public static int[] reverse(int[] arrays){
            int[] result = new int[arrays.length];
    
            //反转的操作
            for (int i = 0, j=result.length-1;i <arrays.length ; i++,j--) {
                result[j] =arrays[i];
            }
            return result;
        }
        //打印数组元素
        public static void printArray(int[] arrays){
            for (int i = 0; i <arrays.length ; i++) {
                System.out.println(arrays[i]+"");
            }
        }
    }
    

    多维数组

    掌握理解,不要深究

    多维数组可以看成是数组的数组,比如二维数组就是一个特殊的一维数组,其每一个元素都是一个一维数组。

    二维数组

    int a[][] = new int [2][5];
    

    解析:以上二维数组a可以看成一个两行五列的数组。

    多画图,才能多理解

    public class ArrayDemo05 {
        public static void main(String[] args) {
            int[][] array = {{1,2},{2,3},{3,4},{4,5}};
    
            for (int i = 0; i <array.length ; i++) {
                for (int j = 0; j <array[i].length; j++) {
                    System.out.println(array[i][j]);
                }
            }
        }
        //打印数组元素
        public static void printArray(int[] arrays){
            for (int i = 0; i <arrays.length ; i++) {
                System.out.println(arrays[i]+"");
            }
        }
    }
    

    Arrays类讲解

    数组的工具类java.util.Arrays

    由于数组对象本身并没有什么方法可以供我们调用,但API中提供了一个工具类Arrays供我们使用,从而可以对数据对象进行一些基本的操作

    查看JDK帮助文档

    Arrays类中的方法都是static修饰的静态方法,在使用的时候可以直接使用类名进行调用,而“不用”使用对象来调用(注意是不用而不是不能)

    具有以下常用功能:

    给数组赋值:通过fill方法

    对数组排序:通过sort方法,按升序

    比较数组:通过equals方法比较数组中元素值是否相等

    查找数组元素:通过binarySearch方法能对排序好的数组进行二分查找法操作

    public class ArrayDemo06 {
        public static void main(String[] args) {
            int[] a = {1,2,3,4,9090,5555,656};
            //System.out.println(a);//[I@74a14482
    
            //打印数组元素Arrays.toString
            //System.out.println(Arrays.toString(a));
            //printArray(a);
            Arrays.sort(a);//数组进行排序:升序
            System.out.println(Arrays.toString(a));
    
            Arrays.fill(a,0);//数组填充
            System.out.println(Arrays.toString(a));
        }
    
        //不要重复造轮子
        public static void printArray(int[]a){
            for (int i = 0; i <a.length ; i++) {
                if (i==0){
                    System.out.print("[");
                }
                if (i==a.length-1){
                    System.out.print(a[i]+"]");
                }else{
                    System.out.print(a[i]+", ");
                }
    
            }
        }
    }
    
    

    冒泡排序

    重要

    冒泡排序无疑是最出名的算法排序之一,总共有八大排序。

    冒泡的代码还是相当简单的,两层循环,外层冒泡轮数,里层依次比较

    当我们看到嵌套循环,应该立马可以得出这个算法的时间复杂度为O(n2)

    public class ArrayDemo07 {
        public static void main(String[] args) {
            int[]a = {1,2,5,500,978,22};
            int[] sort = sort(a);//调用完我们自己写的排序方法以后,返回一个排序后的数组
    
            System.out.println(Arrays.toString(sort));
        }
        //冒泡排序
        //1.比较数组中,两个相邻的元素,如果第一个数比第二个数大,我们就交换他们的位置
        //2.每一次比较,都会产生出一个最大,或者最小的数字
        //3.下一轮则可以减少一次比较
        //4.依次循环,直到结束
        public static int[] sort(int[] array){
            int temp =0;
            //外层循环,判断我们这个要走多少次
            for (int i=0;i<array.length-1;i++){
    
                boolean flag = false;//通过flag标识位减少没有意义的比较
    
                //内层循环,比价判断两个数,如果第一个数,比第二个数大,则交换位置
                for (int j = 0; j <array.length-1-i ; j++) {
                    if (array[j+1]>array[j]){
                        temp = array[j];
                        array[j] = array[j+1];
                        array[j+1] = temp;
                        flag = true;
                    }
                }
                if (flag==false){
                    break;
                }
            }
            return array;
        }
    }
    

    这个案例我敲起来有难度,主要是逻辑问题,先放着,先去后边

    稀疏数组

    扩展内容,理解就好,不需要深究!

    稀疏数组是一种数据机构

    稀疏数组介绍:

    当一个数组中大部分元素为0,或者为同一值的数组时,可以使用稀疏数组来保存该数组。

    稀疏数组的处理方式:

    记录数组一共有几行几列,有多少个不同值

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

    //稀疏数组主要是思维
    public class ArrayDemo08 {
        public static void main(String[] args) {
            //1.创建一个二维数组 11*11,    0;没有棋子, 1:黑色棋子,2:白色棋子
            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+"	");
                }
                System.out.println();
            }
            //0太多,转换为稀疏数组保存
            //获取有效值的个数
            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个数:"+sum);
    
    
            //2.创建一个稀疏数组的数组
            int[][] array2 = new int[sum+1][3];
    
            array2[0][0] = 11;
            array2[0][1] = 11;
            array2[0][2] = sum;
    
            //遍历二维数组,将非零的值,存放稀疏数组中
            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]+"	"
                +array2[i][1]+"	"
                +array2[i][2]+"	");
            }
            System.out.println("=============");
            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];
            }
            //3.打印
            //输出原始的数组
            System.out.println("输出还原 的数组");
    
            for (int[] ints :array3  ) {
                for (int anInt : ints){
                    System.out.print(anInt+"	");
                }
                System.out.println();
            }
        }
    }
    
    

    稀疏数组总结:

    发散思维,一开始不理解正常,,不用深究。

    本子复习笔记资料源自B站UP主:狂神说

    点击此处跳转B站视频

  • 相关阅读:
    1648 最大和
    poj2243
    Codevs 2307[SDOI2009]HH的项链
    2597 团伙
    一个JavaWeb项目中使用的部分技术
    Oracle 11g 学习3——表空间操作
    iOS实现抽屉效果
    用shell脚本实现linux系统上wifi模式(STA和soft AP)的转换
    Codeforces Round #243 (Div. 1)——Sereja and Two Sequences
    站点选择配色诀窍
  • 原文地址:https://www.cnblogs.com/XING-ZHI-JI-DA-XUE/p/14194016.html
Copyright © 2011-2022 走看看