【原创】Java中的数组基础

2023-03-03 20:44:04 浏览数 (1)

数组(连续的存储空间): 使用数组的原因:

代码语言:javascript复制
对相同类型的数据进行分类,便于管理,查找,避免大量变量的定义

数组在内存中的存储:

代码语言:javascript复制
数组在内存中是一组连续的存储空间,而变量是独立的存储空间

数组的概念:

代码语言:javascript复制
数组是一个特殊的变量,用于存储相同数据类型的一组数。

数组的定义:

代码语言:javascript复制
1. 数据类型 数组名;
只声明数组,未进行分配空间和赋值。
2. 数据类型 数组名 = new 数据类型[大小];
声明数组并分配空间
3. 数据类型[] 数组名 = {数据1,数据2,数据3....数据n};

注意:

代码语言:javascript复制
1.整数型数组中可以存放字符类型数据。
2.定义数组并分配空间,未进行赋值时,系统会给数组添加默认值(默认值和全局变量的默认值一致):
 int类型默认值为0,double类型默认值为0.0,String类型默认值为null

数组长度:数组名.lenght; 数组的下标(索引):数组中的每个元素都有对应的下标,第一个元素对应的下标为0,以此类推。 获取数组指定下标的元素:

代码语言:javascript复制
数组名[i]:i表示数组下标 

遍历数组:

代码语言:javascript复制
for (int i = 0 ; i < 数组名.lenght;i  ){
       System.out.println(数组名[数组下标]);
}

数组的常用算法: 数组的扩容: 由于数组无法动态改变大小,所以已经分配空间并赋值的数组中无法添加元素,故数组的扩容需要定义新的数组,步骤如下:

代码语言:javascript复制
1.定义一个新数组,其大小为原数组大小 N;
2.复制原数组的元素到新数组。

求最值(擂台算法)

代码语言:javascript复制
求最大值和最小值
1.定义一个新变量用于保存最大值或最小值。
2.循环依次将数组中的元素与定义的变量进行比较,将大的或小的元素赋值给定义的变量
3.最后输出定义的变量

数组中常用的工具类Arrays(通过import java.util.Arrays进行导入)

代码语言:javascript复制
Arrays.toString(数组名);  打印数组元素
Arrays.store(数组名);  数组升序排序

反转数组思路:将数组从中间分割,交换数组前后数据 冒泡排序算法(重点)

代码语言:javascript复制
循环对比将数组进行排序,可以升序排序,也可以降序排序。
int temp;
int[] array = {5,1,2,3,6,4,9};
for (int i = 0 ; i < array.lenght -1;i  ){
      for (int j = 0 ; j < array.lenght -1 -i; j  ){
            if(array[j] > array[j   1]){
                  temp = array[j];
                  array[j] = array[j 1];
                  array[j 1] = temp;
             }
      }
}
System.out.println(Arrays.toString(array));

插入排序 将数组排序,然后插入一个数组,使数组依然保持原有的排序规则

代码语言:javascript复制
int[] array = new int[5];
array[0] = 1;
array[1] = 3;
array[2] = 5;
array[3] = 7;
Scanner sc = new Scanner(System.in);
System.out.println("请输入一个数");
int num = sc.nextInt();
int i;
for (int i = 0 ; i < array.lenght -1;i  ){
     if(array[i] > num){
         break;
     }
}
for (int j = array.lenght -1 ; j > 1;j  ){
     array[j] = array[j-1];
}
array[i] = num;
System.out.println(Arrays.toString(array));

0 人点赞