复习: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),赋完值后对应的空间存放对应的值。
如果获取的数组超过声明数组的长度会引起数组下标越界错误
三种初始化
-
静态初始化
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;
}

浙公网安备 33010602011771号