一、数组的动态初始化

1、声明
数据类型[] 数组名;或
数据类型 数组名[];
2、开辟空间
数组名 = new 数据类型[长度];//长度必不可少
3、手动赋值
数组名[下标] = 值;
4、使用(打印、运算、判断等)
System.out.println(数组名[下标]);

【注意事项】

① 数组的元素如果不赋值,也有默认值
int 0
double 0.0
char \u0000
boolean false
引用类型 null
② 访问数组的元素时,下标必须在0——长度-1 的范围内,否则报数组下标越界的异常
③ 数组的长度,可以通过 数组名.length表示,提高代码的维护性
④ 数组的赋值和使用,往往可以通过搭配for循环一起操作
for(int i=0;i<数组名.length;i++){
  //每一个元素表示为:数组名[i]
}

二、数组的静态初始化

步骤1:声明并初始化

语法:数据类型[] 数组名 = new 数据类型[]{值,值,值};
或 数据类型[] 数组名 = {值,值,值};

int[] arr = {3,4,5,6,100};
//int[] arr2 = new int[] {3,4,5,6,100};

步骤2:使用

for(int i=0;i<数组名.length;i++){
  //每一个元素表示为:数组名[i]
}

三、数组的复杂使用

  • 数组的赋值
int[] arr1={1,2,3};
int[] arr2=arr1;  // 引用型赋值,赋的是地址

特点:

  数组属于引用类型,数组型数据是对象,数组中的每个元素相当于该对象的成员变量。

基本类型的赋值,赋的是值(内容),其中一个变量对其更改不影响另外一个
引用类型的赋值,赋的是地址,两个引用共同指向一个地址(对象),所以其中一个引用对其更改影响另外一个

注意:如果希望引用类型赋值时,只赋内容,则可以使用循环赋值的方式,语法:

int[] array2 = new int[array1.length];
for(int i=0;i<array2.length;i++){
array2[i] = array1[i];
}
  • 数组的反转

方式一:

for(int i=0;i<arr.length/2;i++){
//交换两个数 i vs arr.length-1-i
int temp = arr[i];
arr[i] = arr[arr.length-1-i];
arr[arr.length-1-i] = temp;
}

方式二:

//①创建一个新数组,长度=arr.length
int[] newArr = new int[arr.length];
//②逆序赋值
/*
i
0 arr.length-1
1 arr.length-2
*/
for(int i=0,j=arr.length-1;i<arr.length;i++,j--){
newArr[j]=arr[i];
}
//③将新数组的地址赋值给arr
arr=newArr;

四、数组的高级使用

  • 数组的添加
//----------------具体的添加业务----------
//①新建一个数组,长度=arr.length+1
int[] newArr = new int[arr.length+1]; //②依次为新数组的元素赋值
for(int i=0;i<arr.length;i++){
newArr[i] = arr[i];
}
//③将add赋值到新数组的空位上
newArr[newArr.length-1] = add; //④将newArr的地址赋值给arr
arr = newArr;
System.out.println("添加成功!");
  • 数组的插入
//----------------------具体的插入业务-----------

//①创建新数组,长度=arr.length+1
int[] newArr = new int[arr.length+1]; //②循环赋值
for(int i=0;i<arr.length;i++){
newArr[i] = arr[i]; } //③循环后移
for(int i=newArr.length-1;i>index;i--){
newArr[i]=newArr[i-1]; } //④将新元素赋值到index位置上
newArr[index] = add; //⑤将newArr的地址赋值给arr
arr = newArr;
System.out.println("插入成功!");

五、二维数组

二维数组其实就是 一维数组的组合,也就是一维数组的定义类型又为一维数组

方式一:动态初始化

1.声明

数据类型[][] 数组名;或
数据类型 数组名[][];
数据类型[] 数组名[];

int[][] num;
int[] num[];
int num[][];

2.开辟空间

情况1:固定列数
数组名 = new 数据类型[行数][列数];
情况2:不固定列数
数组名 = new 数类型[行数][];

3.赋值
情况1:固定列数

for(int i=0;i<nums.length;i++){//i:行数
for(int j=0;j<nums[i].length;j++){//j:列数
nums[i][j]=值;
}
}

情况2:不固定列数

for(int i=0;i<nums.length;i++){//i:行数
nums[i]=new 数据类型[长度];
for(int j=0;j<nums[i].length;j++){//j:列数
nums[i][j]=值;
}
}

4.使用(打印、求和、最值)

for(int i=0;i<nums.length;i++){//i:行数
for(int j=0;j<nums[i].length;j++){//j:列数
System.out.print(nums[i][j]);
}
}

方式二:静态初始化

1.声明并初始化

数据类型[][] 数组名={{},{},{}};

数据类型[][] 数组名=new 数据类型[][]{{},{},{}};

2.使用(打印、求和、最值)

for(int i=0;i<nums.length;i++){//i:行数
for(int j=0;j<nums[i].length;j++){//j:列数
System.out.print(nums[i][j]);
}
}

Java数组的使用的更多相关文章

  1. Java 数组

    数组对于每一门编程语言来说都是重要的数据结构之一,当然不同语言对数组的实现及处理也不尽相同. Java语言中提供的数组是用来存储固定大小的同类型元素. 你可以声明一个数组变量,如numbers[100 ...

  2. 第5章 Java数组

    1.什么是数组 数组可以想象成一个巨大的盒子,这个盒子里面存放的是同一个数据类型的数据 例如:int[] scores = {78,68,94,93}; 2.如何使用Java中的数组 2.1申明数组 ...

  3. Java 数组基础

    数组 数组(Array):相同类型数据的集合. 定义数组 方式1(推荐,更能表明数组类型) type[] 变量名 = new type[数组中元素的个数]; 比如: int[] a = new int ...

  4. Java数组及其内存分配

    几乎所有的程序设计语言都支持数组.Java也不例外.当我们需要多个类型相同的变量的时候,就考虑定义一个数组.在Java中,数组变量是引用类型的变量,同时因为Java是典型的静态语言,因此它的数组也是静 ...

  5. [转载]Java数组扩容算法及Java对它的应用

    原文链接:http://www.cnblogs.com/gw811/archive/2012/10/07/2714252.html Java数组扩容的原理 1)Java数组对象的大小是固定不变的,数组 ...

  6. Java数组技巧攻略

      Java数组技巧攻略 0.  声明一个数组(Declare an array) String[] aArray = new String[5]; String[] bArray = {" ...

  7. Java数组扩容算法及Java对它的应用

    1)Java数组对象的大小是固定不变的,数组对象是不可扩容的.利用数组复制方法可以变通的实现数组扩容.System.arraycopy()可以复制数组.Arrays.copyOf()可以简便的创建数组 ...

  8. Java数组与vector互转

    Java数组与vector互转 /* Object[] object1 = null ; //数组定义 Vector<Object> object2;//Vector定义 object2 ...

  9. 比较Java数组,ArrayList,LinkedList,Vector 性能比较

    public class PerformanceTester { public static final int TIMES=100000; public static abstract class ...

  10. Java数组的12个常用方法

    以下是12个关于Java数组最常用的方法,它们是stackoverflow得票最高的问题. 声明一个数组 String[] aArray = new String[5]; String[] bArra ...

随机推荐

  1. Qt中添加自定义信号和槽带来的一些问题

    背景: 自己定义了一个类,并在类中添加了槽函数 class XImage : public QWidget { public: XImage(QWidget *p = 0); //重载绘制方法 upd ...

  2. 七、ARM 指令集

    7.1 数据处理指令 7.1.1 数据传送类 MOV 类指令:核内寄存器间的数据传送 加载和存储指令(L/S):核内寄存器与挂在存储器总线上器件的数据传送 注意: 核内寄存器就是 R0-R15 外设寄 ...

  3. react 详细解析学习笔记

    React的介绍: React来自于Facebook公司的开源项目 React 可以开发单页面应用       spa(单页面应用) react 组件化模块化  开发模式 React通过对DOM的模拟 ...

  4. DUBBO原理、应用与面经总结

    研读dubbo源码已经有一段时间了,dubbo中有非常多优秀的设计模式和示例代码值得学习,但是dubbo的调用层级和方法链都较为繁杂,如果不对源码思路进行梳理则很容易忘却,因此总结一篇研读心得,从阅读 ...

  5. H5 FormData对象

    FormData对象 2018年01月08日 14:31:53 阅读数:2635 FormData对象,可以把所有表单元素的name与value组成一个queryString,提交到后台. 在使用aj ...

  6. POJ 2112 Optimal Milking ( 经典最大流 && Floyd && 二分 )

    题意 : 有 K 台挤奶机器,每台机器可以接受 M 头牛进行挤奶作业,总共有 C 头奶牛,机器编号为 1~K,奶牛编号为 K+1 ~ K+C ,然后给出奶牛和机器之间的距离矩阵,要求求出使得每头牛都能 ...

  7. 【BZOJ2460】元素(拟阵)

    题意:给定n个物品,每个物品有属性x和价值y,要求从中选出一些使得价值和最大并且其中没有属性xor和为0的非空子集 n<=1000,x<=1e18,y<=1e4 思路:没有xor和为 ...

  8. 【CF1249F】Maximum Weight Subset(贪心)

    题意:给定一棵n个点带点权的树,要求从中选出一个点集,使得这些点两两之间距离都大于K,求最大点权和 n,K<=2e2,1<=a[i]<=1e5 思路:树形DP显然可做,极限是n方,然 ...

  9. SQL语句之-简单查询

       SQL 语句的语法顺序是: SELECT[DISTINCT] FROM WHERE GROUP BY HAVING UNION ORDER BY 一.查询SELECT 1.查询全部列:SELEC ...

  10. Python学习笔记(三)- SyntaxError: Non-ASCII character '\xe7' in file

    在编辑Python时,当有中文输出或者注释时,出现错误提示:“SyntaxError: Non-ASCII character '\xe7' in file“ 原因:python的默认编码文件是用的A ...