后端之数组

本文详细讲解了Java中数组的概念,包括其定义、不同初始化方式(动态与静态)、索引访问规则、常见问题如索引越界和空指针异常,以及实例演示了数组的遍历、元素数量获取、最值计算和数据交换。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

数组

 

定义:

  • 数组(array)是一种用于存储多个相同类型数据的存储模型
  • 要存储的数据通常都是同类型数据,例如:考试成绩

格式

格式一:数据类型 [ ]   变量名
范例:              int[ ]   arr
定义了一个int类型的数组,数组名是arr(常用)
格式二:数据类型       变量名[ ]
范例:            int             arr[ ]
定义了一个int类型的变量,变量名是arr数组(不常用)

数组初始化

 数组初始化概述
Java中的数组必须先初始化,然后才能使用
所谓初始化:就是为数组中的数组元素分配内存空间,并为每个数组元素赋值

动态初始化

初始化时只指定数组长度,由系统为数组分配初始值

格式:数据类型 [ ] 变量名 =  new  数据类型[数组长度];
范例:        
int [ ]     arr   =  new           int[3];

静态初始化

静态初始化:初始化时指定每个数组元素的初始值,由系统决定数组长度

格式:数据类型 [ ] 变量名 =  new  数据类型[ ] { 数据1 , 数据2 , 数据3 , ……} ;
范例:         int [ ]       arr =  new           int[ ] { 1 , 2 , 3 } ;

简化格式:数据类型 [ ] 变量名 = { 数据1 , 数据2 , 数据3 , ……} ;
范例:                int [ ]       arr = { 1 , 2 , 3 } ;

数组元素访问

数组变量访问方式
格式:数组名

数组内部保存的数据的访问方式
格式:数组名[索引]

索引是数组中数据的编号方式
作用:索引用于访问数组中的数据使用,数组名[索引]等同于变量名,是一种特殊的变量名
特征①:索引从0开始
特征②:索引是连续的
特征③:索引逐一增加,每次加1

数组元素访问

  •     编号从1开始
  •     计算机中索引从0开始

内存分配

Java 程序在运行时,需要在内存中分配空间。为了提高运算效率,就对空间进行了不同区域的划分,因为每一片区域都有特定的处理数据方式和内存管理方式

栈内存(存储局部变量)

定义在方法中的变量,例如:arr

使用完毕,立即消失

堆内存

存储new出来的内容(实体,对象)
数组在初始化时,会为存储空间添加默认值数组在初始化时,会为存储空间添加默认值
整数:默认值0
浮点数:默认值0.0
布尔值:默认值false
字符:默认值是空字符
引用数据类型(String):默认值是null

每一个new出来的东西都有一个地址值
使用完毕,会在垃圾回收器空闲时被回收

数组操作的两个常见小问题

  • 索引越界

访问了数组中不存在的索引对应的元素,造成索引越界问题

  •  空指针异常

访问的数组已经不再指向堆内存的数据,造成空指针异常

null:空值,引用数据类型的默认值,表示不指向任何有效对象

 常见操作

遍历

实例:

创建一个char类型的36个元素的数组,前26个元素放置'A'-'Z',  后10个元素放置'0'-'9'。

使用for循环访问所有元素并打印出来。

提示:char类型数据运算 'A'+1 -> 'B','0'+1 -> '1'

public class Array5 {
    public static void main(String[] args) {
//        1.定义数组
        char[] arr = new char[36];
        char front = 'A';
        char behind = '0';
//        2.1对数组遍历
        for (int i = 0; i < arr.length; i++) {
            if (i < 26){
                arr[i] = front;
                front++;
            }else{
                arr[i] = behind;
                behind++;
            }
            //        3.2打印元素
            System.out.print(arr[i]);
        }
        }
    }

 获取数组元素数量

格式:数组名.length
范例:arr.length

  实例:

输入数组{4,6,7,8,1,2,5},最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。  

public class Array6 {
    public static void main(String[] args) {
        int[] arr = {4, 6, 7, 8, 1, 2, 5};
//        1:定义一个变量max,用于保存最大值;min保存最小值
//        2:取数组中第一个数据作为变量的初始值
        int max = arr[0];
        int min = arr[0];
        int num1 = 0;
        int num2 = 0;
//        3:与数组中剩余的数据逐个比对,每次比对将最大值保存到变量中
        for (int x = 0; x < arr.length; x++) {
            if (arr[x] > max) {
                max = arr[x];
//      找出最大值还不够,还要找出最大值下标
                num1 = x;
            }
        }
//        3:与数组中剩余的数据逐个比对,每次比对将最小值保存到变量中
        for (int x = 0; x < arr.length; x++) {
            if (arr[x] < min) {
                min = arr[x];
// 最小值同理,找出最小值还不够,还要找出最小值下标
                num2 = x;
            }
        }
//      4:循环结束后打印变量的值
        System.out.println("max:"+max);
        System.out.println("min:"+min);
        System.out.println("最大值在原数组中是第"+(num1+1)+"个");
        System.out.println("最小值在原数组中是第"+(num2+1)+"个");

//        交换元素位置
//       最大的与第一个元素交换
        arr[num1] = arr[0];
        arr [0] = max;
//        最小的与最后一个元素交换
        arr[num2] = arr[6];
        arr [6] = min;
//        输出最终数组
        System.out.println("最终打印的数组为:");
        for (int x = 0; x < arr.length; x++) {
            System.out.print(arr[x]);
        }
    }
}

获取最值

int[] arr = {12,45,98,73,60};
1:定义一个变量,用于保存最大值(或最小值)
2:取数组中第一个数据作为变量的初始值
int max = arr[0];
3:与数组中剩余的数据逐个比对,每次比对将最大值保存到变量中
for(int x=1; x<arr.length; x++) {  if(arr[x] > max) {  max = arr[x]; }}
4:循环结束后打印变量的值
System.out.println("max:"+max);

 实例:B哥去参加青年歌手大奖赛,有10个评委打分,(去掉一个最高一个最低)求平均分是多少? 

评委打分:99,97,96,95,94,92,91,90,88,100

public class Array10 {
    public static void main(String[] args) {
        //   输入数据
        int [] oldScore ={99,97,96,95,94,92,91,90,88,100};
        int max = 0;
        int min = oldScore[0];   //最小值的初始值不能为0,否则无法比较输出
        int sum = 0;
//    数组中的数据逐个比对,每次比对将最大值保存到变量中
        for (int x = 0; x < oldScore.length; x++) {
            if (oldScore[x] > max) {
                max = oldScore[x];  //找出最大值
            }

        for (int i = 0; i < oldScore.length; i++)
            if (oldScore[i]<min){
                min =  oldScore[i];  //找出最小值
            }

            sum += oldScore[x];
        }
        System.out.println(max);
        System.out.println(min);
        System.out.println("平均分:"+(sum-max-min)/(oldScore.length-2));
            }
        }

输出结果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值