第05章 数组、排序和查找
创始人
2024-05-07 14:33:12
0

数组

基本介绍

数组可以存放多个同一类型的数据,数组也是一种数据类型,是引用类型。

即:数组就是一组数据。

数组的使用

1、数组的定义

方法一:
数据类型[] 数组名 = new 数据类型[大小]
说明:int[] a = new int[5]; //创建一个数组,名字a,存放5个int。
单独声明: new[]{1,2,3,4};方法二:
int[] a;   //先声明
a = new int[5]; // 再new方法三 静态初始化:
数据类型 数组名[] = {元素值,元素值...}
int[] a = {2,3,4,5,6,7}声明空数组: new int[0]

2、数组的引用

数组名[下标/索引]

注意细节

1、数组是多个相同数据类型的组合,实现对这些数据的同意管理。【或者满足自动转换】

double[] array1 = {1.1, 2.2, 3.3, 4};  // 4可以自动转换为小数。   

2、数组中的元素可以是任何数据类型,包括基本类型和引用类型。但是不能混用。

3、数组创建后,如果没有赋值,则有默认值。

int、short、byte、long: 0

boolean: flase

String:null

float、double: 0.0

char:\u0000

4、数组的下标是从 0 开始的。

5、数组的下标必须在范围内调用。否则报:下标越界异常

6、数组是引用类型,数组型数据是对象(object)

数组赋值机制

1、基本数据类型赋值,这个值是具体的数据,而且相互不影响,赋的是值。

2、数组在默认情况下是引用传递,赋的值是地址。

值传递/值拷贝 和 引用传递/地址拷贝 的区别

在这里插入图片描述

数据拷贝

public class Array01{public static void main(String[] args){int[] arr1 = {10, 20, 30};// 1、创建一个新的数组arr2,开辟新的空间,大小为arr1.lengthint[] arr2 = new int[arr1.length];for (int i=1; i
public class Array01{public static void main(String[] args){int[] arr1 = {10, 20, 30};// 1、创建一个新的数组arr2,开辟新的空间,大小为arr1.lengthint[] arr2 = new int[arr1.length];for (int i=0, j=0; i

数组反转

public class Array01{public static void main(String[] args){int[] arr1 = {11,22,33,44,55,66,77};int len = arr1.length;for (int i=0; i <= len/2-1; i++) {int temp = arr1[i];arr1[i] = arr1[len-1-i];arr1[len-1-i] = temp;}for (int i=0; i

数组添加

实现动态的给数组添加元素,实现对数组的扩容

1、原始数组使用静态分配: int[] arr = {1,2,3};

2、增加元素,直接放在数组的最后:arr = {1,2,3,4}

3、用户可以通过如下方法来决定是否继续添加。添加成功,是否继续添加? Y\N

import java.util.Scanner;
public class Array01{public static void main(String[] args){int[] arr1 = {1,2,3};while(true){System.out.println("是否添加? y/n");Scanner myScanner = new Scanner(System.in);char answer = myScanner.next().charAt(0);if (answer == 'y'){System.out.println("请输入添加的值");int addNum = myScanner.nextInt();// 创建新的数组用于添加元素。int[] arr2 = new int[arr1.length + 1];for (int i=0; i < arr1.length; i++) {arr2[i] = arr1[i];}arr2[arr2.length-1] = addNum;arr1 = arr2;System.out.println("数据添加成功");for(int i=0; i

排序

排序是将一组数据,按照指定的顺序进行排列的过程。【之后详细介绍】

排序的分类:

1、内部排序

指将需要处理的所有数据都加载到内部存储器中进行排序,包括(交换式排序法,选择式排序法和插入式排序法)

2、外部排序法

数据量过大,无法全部加在到内存中,需要借助外部存储进行排序。包括(合并排序法和直接合并排序法)

冒泡排序:

冒泡排序的特点:
在这里插入图片描述
方法一:

public class Array01{public static void main(String[] args){int[] arr1 = {1,8,7,4,6,5};for (int i=0; i<(arr1.length-1); i++) {for (int z = i; z arr1[z]){int temp = arr1[z];arr1[z] = arr1[i];arr1[i] = temp;}} }for (int i=0; i

方法二

public class Array01{public static void main(String[] args){int[] arr1 = {1,8,7,4,3,5};for (int x=0; x arr1[i+1]){int temp = arr1[i+1];arr1[i+1] = arr1[i];arr1[i] = temp;}}for (int z=0; z

查找

1、顺序查找

2、二分查找【算法中详细介绍】

多维数组

public class Array01{public static void main(String[] args){/*请用二维数组输出如下图形:0 0 0 0 0 00 0 1 0 0 0 0 2 0 3 0 00 0 0 0 0 0*/int[][] array1 = {{0, 0, 0, 0, 0, 0}, {0, 0, 1, 0, 0, 0},{0, 2, 0, 3, 0, 0},{0, 0, 0, 0, 0, 0}};for (int i=0; i < array1.length; i++) {for (int z=0; z < array1[i].length; z++) {System.out.print(array1[i][z] + " ");}System.out.println();}}
}

二维数组的使用

1、动态初始化

  • 语法: 类型[][] 数组名 = new 类型[大小][大小];

  • 比如:int a[][] = new int[2][3];

二维数组在内存中的表现形式:

注意:在第一层保存的是地址,第二层才是数据。发散思维,想想三维四维数组。
在这里插入图片描述

2、动态初始化

  • 先声明: 类型[][] 数组名;

  • 再定义(开辟空间) 数组名 = new 类型[大小][大小]

  • 比如:

    int[][] array01;
    array01 = new int[2][3];
    
```Java
public class Array01{public static void main(String[] args){/* 方法一 */// int[][] array01;   // 先声明// array01 = new int[2][3];/* 方法二 */int[][] array01 = new int[2][3];// 输出二维数组中的元素for (int i=0; i

3、动态初始化 → 列数不确定

public class Array01{public static void main(String[] args){// 创建一个二维数组,但只确定一维数组的个数,所以空着。int[][] arr01 = new int[4][]; // 遍历arr的每个一维数组。for (int i=0; i

4、静态初始化

  • 定义: 类型[][] 数组名 = {{值1,值2 …},{值1,值2 …},{值1,值2 …},{值1,值2 …}}
int[][] arr = {{1,1,1},{2,2,2},{3}};

二维数组使用细节和注意事项

1、一维数组的声明方式有:

int[] arr01 = new int[2]; 或者 int arr01[] = new int[2];

int[] arr01 = new int[]{1,2}

2、二维数组的声明方式有:

int[][] arr01 = new int[2][3];

或者 int arr01[][] = new int[2][3];

int[] arr01[] = new int[2][3];

3、二维数组世纪上是由多个一维数组组成的,它的一维数组的长度可以相同,也可以不同。

比如: int[][] map = {{1,2}{3,3,4}};

这种不相同长度的,我们称为:列数不等 的二维数组。

测试题

1、判断

int[] x,y[];    //声明x为int类型的一维数组,y为int类型的二维数组

在这里插入图片描述
总结:关键是类型的对应,即int对应int,int[] 对应 int[]

2、BD
在这里插入图片描述

3、 已知有个升序的数组,要求插入一个元素,该数组的顺序仍然是升序。

比如:{10,12,40, 90} 添加43后,数组为{10,12,40,43,90}

public class Array01{public static void main(String[] args){int[] arr01 = {10, 12, 40, 90};int intsertIndex = -1;int value = 42;int[] arrNew = new int[arr01.length+1];for (int i=0; i value){intsertIndex = i;break;}}if (intsertIndex == -1){intsertIndex = arr01.length;}System.out.println("插入数据的位置为:" + intsertIndex);for (int i=0, j=0; i

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...