数组及其应用

数组

1.什么是数组

1.1数组的定义:

a.数组是相同类型数据的有序集合;
b.数组描述的是相同类型的若干个数据,按照一定先后次序排列组合而成的;
c.每一个数据称作数组元素,通过下标来访问数组元素

2.数组的声明与创建

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

声明数组变量的语法:首选:dataType [] arrayRefVar;不建议:dataType arrayRefVar;

2.2Java中创建数组用new操作符

语法:dataType[ ] arrayRefVar=new dataType[arrays.size];

2.3数组元素的访问通过下标访问的,从0开始;

2.4获取数组长度:arrays.length

2.5数组的四个基本特点

2.5.1数组长度是确定的,一旦被创建数组大小不可改变;
2.5.2数组元素类型必须一致;
2.5.3数组元素可以实任意数据类型,基本类型,引用类型都可以;
2.5.4数组变量属引用型,数组对象本身在堆中的;

3.三种初始化及内存分析

3.1内存分析:Java内存:堆:存放new的对象和数组;可被所有线程共享,不会存放别的对象引用。 栈:存放基本变量类型,引用对象的变量。方法区:可被所有线程共享,包含所有的class 和static变量。

3.2三种初始化:静态初始化:int [] a={1,2,4};//创建+赋值。动态初始化:int [] a=new int [2];a[0]=1;a[1]=4;//先创建再赋值 。数组默认初始化:数组是引用类型,元素相当于类的实例变量,因此,数组已经分配空间,其中每个元素也被隐式初始化。

4.数组边界

4.1下标的合法区间[0,length-1],如果越界则报错

4.2ArrayIndexOutOfBoundsException:数组下标越界异常

5.数组的使用

5.1 普通For循环;for-each循环;数组作方法循环;数组作为返回值

6.多维数组

6.1多维数组可以看作数组的数组;

6.2二维数组:int [][]a=new int [1][2];//一行两列的二维数组

7.Arrays工具类讲解

7.1Arrays工具类功能:

7.1.1给数组赋值通过fill方法
7.1.2对数组排序用sort方法
7.1.3比较数组:通过equals方法比较数组中的元素是否相等
7.1.4查找数组元素:通过binarySearch方法能对排序好的数组进行二分查找操作

8.冒泡排序

8.1冒泡排序是最有名的排序算法之一,总共有八大排序

8.2两层循环,外层:判断循环的轮数;内层:比较大小

8.3嵌套循环算法的时间复杂度为O(n^2)

9.稀疏数组

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

9.2稀疏数组处理方式:

记录数组以一共有几行几列,几个不同的元素;
把具有不同值的元素和行列及值记录在一个小规模的数组中,从而缩小程序规模。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值