数组的声明和创建
int[] nums;//定义(声明)
nums = new int[10];//可以存放10个int类型的数字(创建)
nums[0] = 1;//给数组元素赋值
...
nums.length();//数组的长度
三种初始化及内存分析
- 内存分析
Java内存.png
栈、堆.png
声明的时候数组不存在,只有创建的时候才存在,一般来说声明和创建一起写
int[] nums = new int[10];
- 三种初始化
//静态初始化
int[] a = {1,2,3,4,5};
//动态初始化(包含默认初始化,默认没有赋值的全部为0)
int[] b = new int[10];
b[0] = 10;
//引用初始化(新建一个Man类)
Man[] mans = {new Man(),new Man()};
下标越界
数组对象本身是在堆中
ArrayIndexOutOfBoundsException:数组下标越界
数组的使用
普通的for循环
for-each循环
int[] arrays = {1,2,3,4,5};
//JDK1.5之后,没有下标
for(int array:arrays){
System.out.println(array);
}
- 数组作方法入参
- 数组作为返回值
public class Demo01
{
public static void main(String[] args) {
int[] arrays = {1,2,3,4,5};
printArray(arrays);
System.out.println();
maxNumber(arrays);
// System.out.println();
sumNumber(arrays);
int[] ints = reverseNumber(arrays);//把数组当作返回值
printArray(ints);
}
//反转数组(把数组当作返回值)
public static int[] reverseNumber(int[] arrays){
int[] reverse = new int[arrays.length];
for (int i = 0,j = arrays.length-1; i < arrays.length; i++,j--){
reverse[j] = arrays[i];
}
return reverse;
}
//打印数组元素
public static void printArray(int[] arrays){
for (int i = 0; i < arrays.length; i++) {
System.out.print(arrays[i]+" ");
}
}
//计算数组中最大值
public static void maxNumber(int[] arrays){
int max = arrays[0];//写在最外面
for (int i = 0; i < arrays.length; i++) {
if (arrays[i]>max)
{
max = arrays[i];
}
}
System.out.println(max);
}
//计算数组元素和
public static void sumNumber(int[] arrays) {
int sum = 0;
for (int i = 0; i < arrays.length; i++) {
sum += arrays[i];
}
System.out.println(sum);
}
}
二维数组
int arr[][] = new int[2][2];
int [][]arr = new int[2][2];
arr.png
Array类
public class Demo02 {
public static void main(String[] args) {
int[] a = {9,8,4,3};
System.out.println(a);//打印的为地址
//打印数组元素
System.out.println(Arrays.toString(a));
//调用方法
printArray(a);
//数组进行排序:生序
Arrays.sort(a);
System.out.println(Arrays.toString(a));
//数组填充
// Arrays.fill(a,0);
// System.out.println(Arrays.toString(a));
//数组填充,下标为1-3填充
Arrays.fill(a,1,3,0);
System.out.println(Arrays.toString(a));
}
//自己写输出方法
public static void printArray(int[] a){
System.out.print("[");
for (int i = 0; i < a.length; i++){
if (i!=0){
System.out.print(","+" ");
}
System.out.print(a[i]);
}
System.out.println("]");
}
}
冒泡排序
时间复杂度为O(n2)
public class Demo03 {
public static void main(String[] args) {
int[] a={1,22,2,33,44,54,12};
int[] sort = sort(a);
System.out.println(Arrays.toString(sort));
}
//1、比较数组中,两个相邻的元素,如果第一个数比第二个数大,我们就交换他们的位置
//2、每一次比较,都会产生一个最大、最小的数字
//3、下一轮则可以减少一次排序
//4、一次循环,直到结束!!
public static int[] sort(int[] array){
int temp;
for (int i = 0; i < array.length; i++) {
for (int j = 0; j < array.length - 1 -i; j++) {
if (array[j] > array[j+1])
{
temp = array[j];
array[j] = array[j+1];
array[j+1] = temp;
}
}
}
return array;
}
}
进阶
public class Demo04 {
public static void main(String[] args) {
int[] a = {9,8,5,3,6};
int[] sort = sort(a);
System.out.println(Arrays.toString(sort));
}
public static int[] sort(int[] array){
int temp;
for (int i = 0; i < array.length; i++) {
boolean flag = false;//通过flag标识位减少没有意义的比较
for (int j = 0; j < array.length - 1 - i; j++) {
if (array[j] > array[j+1]){
temp = array[j];
array[j] = array[j+1];
array[j+1] = temp;
flag = true;
}
}
if (flag == false){
break;
}
}
return array;
}
}
稀疏数组
是一个数据结构
稀疏数组.png
public class Demo05 {
public static void main(String[] args) {
int[][] array = new int[11][11];
array[1][2] = 1;
array[2][3] = 2;
System.out.println("输出原数组:");
for (int[] ints : array) {
for (int anInt : ints) {
System.out.print(anInt+"\t");
}
System.out.println();
}
System.out.println("输出稀疏数组:");
int sum = 0;
for (int i = 0; i < array.length; i++) {
for (int j = 0; j < array.length; j++) {
if (array[i][j]!=0)
{
sum ++;
}
}
}
int[][] arr = new int[sum+1][3];
arr[0][0] = 11;
arr[0][1] = 11;
arr[0][2] = sum;
//遍历二维数组,将非零的值,存放稀疏数组中
int count = 0;
for (int i = 0; i < array.length; i++) {
for (int j = 0; j < array.length; j++) {
if (array[i][j]!=0){
count++;
//行由sum决定
arr[count][0] = i;
arr[count][1] = j;
arr[count][2] = array[i][j];
}
}
}
for (int i = 0; i < arr.length; i++) {
System.out.println(arr[i][0]+"\t"+
arr[i][1]+"\t"+
arr[i][2]+"\t");
}
System.out.println("还原:");
int[][] a = new int[arr[0][0]][arr[0][1]];
//i从1开始,因为第0行不需要还原
for (int i = 1; i < arr.length; i++) {
a[arr[i][0]][arr[i][1]]=arr[i][2];
}
for (int[] ints : a) {
for (int anInt : ints) {
System.out.print(anInt+"\t");
}
System.out.println();
}
}
}