1具体内容
1.1什么事数组
所谓数组,是有序的元素序列。若将有限个类型相同的变量集合命名,那么这个名称为数组名。组成数组的各个变量称为数组的分量,也称为数组的元素,有事也称为下标变量。用于区分数组的各个元素的数字编号称为下标。
在js中,数组没有数据类型限制,并且可以随意扩容。Java中的数组就是将相同数据类型的数据进行存储数据格式。并且存储到数组中的数据都会自动生成一个编号,称之为索引值或下标。然后数组是通过操作索引值对数据进行存取。索引值从0开始。并且java中的数据是定容,统一数据类型的。
1.2java数组的特点
- java数组是一种引用数据类型
- java数组中的数据类型必须统一
- java数组是定长的(长度一旦确定就不能变化)
- 数组的重新赋值,只能通过标准格式,不能使用简化格式赋值
- 初始化数组是如果没有直接赋值,那么数组中元素的默认值,整数:0浮点数:0.0字符:‘\u0000’布尔型:false引用类型:null
- 因为数组是定长的,如果想扩容只能创建一个新的数组。Arrays.copyOf(原始数组,长度)
1.3数组的定义
语法
定义有容量的数组
数据类型[] 数组变量 = new 数据类型[数组容量];
定义有初始化数据的数组
数据类型[] 数组变量 = new 数组类型[] {数据1,数据2…};
直接赋值创建(静态创建),定义和赋值必须写在一起
数据类型[] 数组变量 = {数据1,数据2…};
实例代码
/**
* author:hzk
*/
public class Ary {
public static void main(String[] args) {
//int[] num = {1, 2 ,3};
// int[] num = new int[3];
int[] num = new int[]{1,2,3};
for (int i=0;i<num.length;i++){
System.out.println(num[i]);
}
System.out.println("====================");
for (int n:num){
System.out.println(n);
}
String[] name = {"张三","李四","王五"};
System.out.println(name[0]);
System.out.println(name[1]);
System.out.println(name[2]);
System.out.println("====================");
for (String n:name){
System.out.println(n);
}
System.out.println("====================");
for (int i=0;i< name.length;i++){
System.out.println(name[i]);
}
}
}
1.4数组的使用
语法
创建数组[] 数组变量 = new 数据类型[数组容量];
通过数组变量+下标 为数组元素赋值,数组的最大下标只能取到“数组容量-1”
数组变量[下标1] = 数据1;
…
数组变量[数组容量-1] = 数据n;
通过数组变量+下标访问数组元素
System out println(数组变量[下标])
实例代码
String[] name = {"张三","李四","王五"};
System.out.println(name[0]);
System.out.println(name[1]);
System.out.println(name[2]);
1.5数组的遍历
方式一:for+索引
int[] num = new int[]{1,2,3};
for (int i=0;i<num.length;i++){
System.out.println(num[i]);
}
fangshier:for each遍历
String[] name = {"张三","李四","王五"};
for (String n:name){
System.out.println(n);
}
1.6数组的操作
求最大值最小值以及最大值的下标和最小值的下标
/**
* author:hzk
*/
public class MaxMin1 {
public static void main(String[] args) {
int posMax = 0;
int posMin =0;
int[] numAry = {3,5,18,1,2,59};
for (int i=1;i<numAry.length;i++){
if(numAry[posMax]<numAry[i]){
posMax = i;
}
if(numAry[posMin]>numAry[i]){
posMin = i;
}
}
System.out.println("最大值为"+numAry[posMax]+"最大值位置为"+posMax+"最小值为"+numAry[posMin]+"最小值位置为"+posMin);
}
冒泡排序
/**
* author:hzk
*/
public class Paixu {
public static void main(String[] args) {
int[] num = {50,20,30,60,15};
for (int i=1;i<num.length;i++){
for (int j=1;j<num.length;j++){
if (num[j-1]>num[j]){
int temp = num[j-1];
num[j-1] = num[j];
num[j] = temp;
}
}
}
for (int n:num){
System.out.print(n+"\t");
}
}
}