Java数据结构之数组

一.数组的定义:
数组是相同类型数据的有序集合。数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成。其中,每一个数据称作一个元素,每个元素可以通过一个索引(下标)来访问它们。

数组示意图(下面的图片描绘了数组 myList。这里 myList 数组里有 10 个 double 元素,它的下标从 0 到 9。):
在这里插入图片描述
二.数组的特点:
(1)长度是确定的。数组一旦被创建,它的大小就是不可以改变的。
(2)其元素必须是相同类型,不允许出现混合类型。元素的类型可以是java 支持的任意类型
(3)数组类型可以是任何数据类型,包括基本类型和引用类型。
(4)数组的元素在堆内存中被分配空间,并且是连续分配的
(5)使用new 关键字对数组进行 内存的分配。每个元素都会被jvm 赋予默认值。
默认规则:整数:0 浮点数:0.0 字符:\u0000 布尔:false 引用数据类型:null。
(6)数组的元素都是有序号的,序号从0开始,0序的。称作数组的下标、索引、角标

三.数组变量的声明:

dataType[] arrayRefVar;   // 首选的方法
 
或
 
dataType arrayRefVar[];  // 效果相同,但不是首选方法

注意: 建议使用 dataType[] arrayRefVar 的声明风格声明数组变量。 dataType arrayRefVar[] 风格是来自 C/C++ 语言 ,在Java中采用是为了让 C/C++ 程序员能够快速理解java语言。

四.数组的优缺点:
优点:
(1)数组定义简单,而且访问很方便
(2)数组可以保存若干个数据。
缺点:
(1)数组的元素的类型必须一致。元素类型必须一致。
(2)连续分配空间在堆中,如果数组的元素很多,对内存的要求更加的严格。
(3)根据内容查找元素效率比较低,需要逐个比较个。
(4)删除元素、插入元素效率比较低,需要移动大量的元素。
(5)数组大小必须定义时给出,而且大多数情况下,数组空间的大小一旦确定后就不能更改
(6)数组没有封装,数组对象只提供了一个数组长度的属性,但是没有提供方法用来操作元素。

五.数组的遍历:
(1)for循环

public class TestArray{
	public static void main(String[] args) {
		int[] array=new int[5];
		//初始化数组元素
		for (int i=0;i<array.length;i++){
			array[i]=9*i;
		}
		//获取元素的值
		for (int i=0;i<array.length;i++){
			System.out.println(array[i]);
		}
	}
}

(2)for-each循环

public class TestArray{
	public static void main(String[] args) {
		int[] array=new int[5];
		//初始化数组元素
		for (int i=0;i<array.length;i++){
			array[i]=9*i;
		}
		//获取元素的值
		for (int temp : array){
			System.out.println(temp);
		}
	}
}

六.多维数组:
(1)定义:多维数组可以看成是数组的数组,比如二维数组就是一个特殊的一维数组,其每一个元素都是一个一维数组,例如:

String str[][] = new String[6][7];

(2)多维数组的动态初始化(以二维数组为例)
1.直接为每一维分配空间

type[][] typeName = new type[typeLength1][typeLength2];

type 可以为基本数据类型和复合数据类型,arraylength1 和 arraylength2 必须为正整数,arraylength1 为行数,arraylength2 为列数。
例如:

int array[][] = new int[8][9];

解析:

二维数组 array可以看成一个8行9列的数组。

2.从最高维开始,分别为每一维分配空间

String s[][] = new String[2][];
s[0] = new String[2];
s[1] = new String[3];
s[0][0] = new String("Good");
s[0][1] = new String("Luck");
s[1][0] = new String("to");
s[1][1] = new String("you");
s[1][2] = new String("!");

解析:
s[0]=new String[2] 和 s[1]=new String[3] 是为最高维分配引用空间,也就是为最高维限制其能保存数据的最长的长度,然后再为其每个数组元素单独分配空间 s0=new String(“Good”) 等操作。

七.Arrays 类:
java.util.Arrays 类能方便地操作数组,它提供的所有方法都是静态的。
具有以下功能:
(1)给数组赋值:通过 fill 方法。
(2)对数组排序:通过 sort 方法,按升序。
(3)比较数组:通过 equals 方法比较数组中元素值是否相等。
(4)查找数组元素:通过 binarySearch 方法能对排序好的数组进行二分查找法操作。

方法描述
public static int binarySearch(Object[] a, Object key)用二分查找算法在给定数组中搜索给定值的对象(Byte,Int,double等)。数组在调用前必须排序好的。如果查找值包含在数组中,则返回搜索键的索引;否则返回 (-(插入点) - 1)
public static boolean equals(long[] a, long[] a2)如果两个指定的 long 型数组彼此相等,则返回 true。如果两个数组包含相同数量的元素,并且两个数组中的所有相应元素对都是相等的,则认为这两个数组是相等的。换句话说,如果两个数组以相同顺序包含相同的元素,则两个数组是相等的。同样的方法适用于所有的其他基本数据类型(Byte,short,Int等)
public static void fill(int[] a, int val)将指定的 int 值分配给指定 int 型数组指定范围中的每个元素。同样的方法适用于所有的其他基本数据类型(Byte,short,Int等)
public static void sort(Object[] a)对指定对象数组根据其元素的自然顺序进行升序排列。同样的方法适用于所有的其他基本数据类型(Byte,short,Int等)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值