复习:java数组

Java数组

数组的定义

  • 数组是相同类型数据的有序集合

  • 数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成

  • 每个数组元素通过下标来访问

 

数组声明和创建

  • 首先必须声明数组变量,才能在程序中使用数组

    dataType[] arrayRefVar;  //首先的方法
    或者
    dataType arrayRefVar[] //效果相同,但不是首先方法
  • Java语言使用new操作符来创建数组,语法如下

 

dataType[] arrayRefVar = new dataType[arraySize]

 

  • 数组的元素是通过索引访问的,数组索引从0开始。

  • 获取数组长度 :arrays.length

 

内存分析

  • java内存分析:

    • java内存

      • 堆:存放new的对象和数组。可以被所有的线程共享,不会存放别的对象引用

      • 栈:存放基本变量类型(会包含这个基本类型的具体数值),引用对象的变量(会存放这个引用在堆里面的具体地址)

      • 方法区:可以被所有的线程共享,包含了所有的class和statix变量

1.声明数组

int[] array = new int[10]

栈里面存放了array对象 而堆里面存放的是10个数组的值,在未给数组赋值时只是开辟了一个空间,默认值为对应类型的默认值(int类型为0,String类型为null),赋完值后对应的空间存放对应的值。

如果获取的数组超过声明数组的长度会引起数组下标越界错误

image-20220817163314060

 

三种初始化

  • 静态初始化

    int[] a ={1,2,3};
    Man[] mans = {new Man(1,10),new Man(2,2)};
  • 动态初始化

    int[] a = new int[2];
    a[0]=1;
    a[1]=2;

     

  • 数组的默认初始化

    • 数组是引用类型,它的元素相当于类的实例变量,因此数组一经分配空间,其中的每个元素也按照实例变量同样的方式被隐式初始化。

 public static void main(String[] args) {
       //静态初始化:创建+赋值,后续不能改变
       int[] a={1,2,3};
       System.out.println(a[0]);

       //动态初始化:包含默认初始化
       int[] b =new int[10];
       b[0] = 10;
       b[1] = 20;
       b[2] = 30;
       System.out.println(b[0]);
       System.out.println(b[1]);
       System.out.println(b[2]);
  }

 

数组的四个基本特点

  • 其长度是确定的。数组一旦被创建,它的大小就是不可以改变的

  • 其元素必须是相同类型,不允许出现混合类型

  • 数组中的元素可以是任何数据类型,包括基本类型和引用类型

  • 数组变量属引用类型,数组也可以看成是对象,数组中的每个元素相当于该对象的成员变量,数组本身就是对象,Java中对象是在堆中的,因此数组无论保存原石类型还是其他对象类型,数组对象本身是在堆中的

 

数组边界

  • 下标的合法区间:[0,length-1],如果越界就会报错

  • ArrayIndexOutOfBoundsException:数组下标越界

  • 小结:

    • 数组是相同数据类型(数据类型可以为任意类型)的有序集合

    • 数组也是对象。数组元素相当于对象的成员变量

    • 数组长度是确定的。不可变的。如果越界,则报错:ArrayIndexOutOfBoundsException

数组使用

  • 普通的for循环

  • for-each循环

  • 数组作方法入参

  • 数组作返回值

  public static void main(String[] args) {
       int[] num = {1,2,3,4,5};

       //打印数组,调用printArray方法
//       printArray(num);
//输出反转数组
       int[] reverse = reverse(num);
     //普通打印数组的方法调用反转数组的方法
       printArray(reverse);


  }

   //反转数组的方法         定义方法时先把该数组传入进去,也就是int[] num
   public static int[] reverse(int[] num){
//定义反转数组输出的结果,使它跟传进来的数组长度一致
       int [] result = new int[num.length];
//在循环中添加j使之等于反转数组的长度-1,然后相对应的i++,j--,再把反转数组的值通过j来一次次赋值给result,相当于改变了传进来的每个数组的下标,使之从后往前
       for (int i = 0,j=result.length-1; i <num.length ; i++,j--) {
           result[j] = num[i];
      }

       return result;
  }

   //打印数组方法
   public static void printArray(int[] num){
       for (int i = 0; i <num.length ; i++) {
           System.out.print(num[i]+" ");
      }
  }

 

多维数组

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

  • 二维数组

int a[][]= new int[2][5]
public static void main(String[] args) {
       //定义一个二维数组
       //[4][2]
       /*
           1,2     array[0]
           2,3     array[1]
           3,4     array[2]
           4,5     array[3]
        */

       int [][] array ={{1,2},{2,3},{3,4},{4,5}};



       //调用方法打印一下二维数组
       //array[0]代表的是1,2
       printArray(array[0]);
       System.out.println("===============");
       //array[0][0]代表的就是1,以此类推
       //单独打印二维数组返回的是一个对象,指明打印的才是具体数组中的数字
       System.out.println(array[0][0]);
       System.out.println("===============");
       //打印array数组
       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[] num){
       for (int i = 0; i <num.length ; i++) {
           System.out.print(num[i]+" ");
      }
  }

Arrays类

  • 数组的工具类java.util.Arrays

  • Arrays类中的方法都是static修饰的静态方法,在使用的时候可以直接使用类名进行调用,而不用使用对线来调用

  • 功能:

    • 给数组赋值:通过fill方法

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

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

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

 public static void main(String[] args) {
       int[] a={12,3123123,442,21312,412};

       //正常普通打印数组会得到一个对象
       System.out.println(a);
       //通过arrays类里面的方法能正常打印数组,类中存在各种方法,也是能够自己写的
       System.out.println(Arrays.toString(a));
       System.out.println("==========");
       //手写的方法打印出该数组,与调用的类的方法打印做对比
       printArray(a);
       System.out.println();
       System.out.println("==========");
       //数组的排序 arrays类中的sort方法,给数组排序,升序
       Arrays.sort(a);
       System.out.println(Arrays.toString(a));

       //填充数组,指定该数组中的下标或者该数组本体赋值为val
//       System.out.println("==========");
//       Arrays.fill(a,0);
//       System.out.println(Arrays.toString(a));

       //让该数组的下标为3的值为0,左开右闭区间,包括左边但不包括右边
       System.out.println("==========");
       Arrays.fill(a,2,3,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 static void main(String[] args) {
       //冒泡排序
       /*
       1.比较数组中,两个相邻的元素,如果第一个数比第二个数大,就交换它们的位置
       2.每一次比较,都会产生一个最大,或者最小的数
       3.下一轮则可少一次循环
       4.依次循环,直至结束
        */

       //随便定义一个无序的数组
       int[] a={12,23,553,123,412,123,11};
       //调用自己写的排序方法,输出排序后的数组
       int[] sort = sort(a);

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

  }
   //冒泡排序方法
   public static int[] sort(int[] array){
       //临时变量
       int temp=0;
       //外层循环,判断要走多少次
       for (int i = 0; i <array.length-1 ; i++) {

           //通过flag标识减少没有意义的比较
           boolean flag=false;

           //内层循环,比较判断两个数,如果第一个数比第二个大,则交换位置
           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;
  }
 
posted @ 2022-08-17 22:48  ywjt  阅读(105)  评论(0)    收藏  举报