一.数组定义
数组是相同类型数据的有序集合,其中每个数据称作一个数组元素,可通过下标来访问
二.数组声明创建
2.1 声明与创建
package com.zhu.array;
public class Demo01 {
public static void main(String[] args) {
int[] nums; //1.声明一个数组,推荐!
//int nums2[];类c++写法,不推荐使用
nums = new int[10];//2.创建一个数组
//int[] nums = new int[10]; 合并写法
//3.给数组元素赋值
nums[0]=1;
nums[1]=2;
nums[2]=3;
nums[3]=4;
System.out.println(nums[0]);
System.out.println(nums[4]);
//4.计算所有元素的和,获取数组长度,length属性
int sum = 0;
for (int i = 0; i < nums.length; i++) {
sum += nums[i];
}
System.out.println(sum);
}
}
2.2 三种初始化及内存分析
new出来的都在堆中
相当于栈里面存放指针
package com.zhu.array;
public class Demo02 {
public static void main(String[] args) {
//静态初始化:声明、创建+赋值
int [] a = {1,2,3,4,5,6,7};
//动态初始化,包含默认初始化,没赋值的默认为0
int [] b = new int[10];
b[0] = 1;
}
}
2.3 下标越界及小结
三.数组使用
package com.zhu.array;
public class Demo03 {
public static void main(String[] args) {
int[] array = {1,2,3,4,5};
//遍历数组,jdk1.5,没有下标
for (int i : array) {
System.out.println(i);
}
System.out.println("====================");
print(array);
System.out.println("====================");
print(reverse(array));
}
//数组作为入参
public static void print(int[] list){
for (int i = 0; i < list.length; i++) {
System.out.print(list[i]+" ");
}
}
//反转数组
public static int[] reverse(int [] list){
int[] result = new int[list.length];
for (int i = 0; i < list.length; i++) {
result[list.length-i-1] = list[i];
}
return result;
}
}
四.多维数组
package com.zhu.array;
public class Demo04 {
public static void main(String[] args) {
int[][] arrays = {{1,2},{3,4},{5,6}};
}
}
五.Arrays类
查看API文档,不要死记硬背
package com.zhu.array;
import java.util.Arrays;
public class Demo05 {
public static void main(String[] args) {
int[] a = {1,5,9,3,6,2};
System.out.println(a);
//打印数组元素Arrays.toString()
System.out.println(Arrays.toString(a));
System.out.println("===================");
//数组排序
Arrays.sort(a);
System.out.println(Arrays.toString(a));
System.out.println("===================");
//数组填充
Arrays.fill(a,1);
System.out.println(a);
}
}
冒泡排序
package com.zhu.array;
import java.util.Arrays;
public class Demo06 {
public static void main(String[] args) {
int[] a = {1,3,6,4,7,5,2};
System.out.println(Arrays.toString(sort(a)));
}
//冒泡排序
public static int[] sort(int[] arrays){
//外层循环,判断循环要走多少次
int tmp;
for (int i = 0; i < arrays.length-1; i++) {
//内层循环,判断每次循环要比较多少次
for (int j = 0; j < arrays.length-1-i; j++) {
if(arrays[j]>arrays[j+1]){ //注意比较的是前后两个数!!
tmp = arrays[j];
arrays[j] = arrays[j+1];
arrays[j+1] = tmp;
}
}
}
return arrays;
}
}
六.稀疏数组
6行7列,8个不同值(除0外);
剩下的行记录各个值所在的坐标
package com.zhu.array;
import java.util.Arrays;
public class Demo07 {
public static void main(String[] args) {
//创建二维数组 11*11,0:没有棋子,1:黑棋,2:白棋
int[][] array = new int[11][11];
array[1][2]=1;
array[2][3]=2;
for (int[] ints : array) {
for (int anInt : ints) {
System.out.print(anInt+"\t");
}
System.out.println();
}
//转换成稀疏数组保存
//获取有效值的个数
int sum=0;
for (int i = 0; i < 11; i++) {
for (int i1 = 0; i1 < 11; i1++) {
if(array[i][i1]!=0){
sum++;
}
}
}
System.out.println("有效值个数为: "+sum);
//创建稀疏数组
int[][] array2 = new int[sum+1][3];
array2[0][0] = 11;
array2[0][1] = 11;
array2[0][2] = sum;
//遍历二维数组,将非零的值,存放到稀疏数组中
int count = 0;
for (int i = 0; i < array.length; i++) {
for (int j = 0; j < array[i].length; j++) {
if(array[i][j]!=0){
count++;
array2[count][0] = i;
array2[count][1] = j;
array2[count][2] = array[i][j];
}
}
}
//输出稀疏数组
for (int[] ints : array2) {
for (int anInt : ints) {
System.out.print(anInt+"\t");
}
System.out.println();
}
//1.读取稀疏数组
int[][] a = new int[array2[0][0]][array2[0][1]];
//2.给其中的元素还原他的值
for (int i = 1; i < array2.length; i++) {
a[array2[i][0]][array2[i][1]] = array2[i][2];
}
for (int[] ints : a) {
for (int anInt : ints) {
System.out.print(anInt+"\t");
}
System.out.println();
}
}
}
七. 数组拷贝