2.1Java数组


在Java中,如果想要保存多个相同类型的值,我们就要使用个数组,例如:保存几本自己喜欢的书,如果使用基本数据类型的话,在数据量大的情况下就非常不方便使用。

一维数组

数组的概念

数组是存储同一种数据类型多个元素的集合。也可以看成是一个容器。
数组既可以存储基本数据类型,也可以存储引用数据类型。

数组一旦初始化,长度不可变。长度确定下来了!!!

数组的定义

一维数组的声明方式: 类型 数组名[] 或 类型[] 数组名:
例如:
int a[];
int[] a1;
double b[];
Date[]c; //对象数组
单独声明数组时不能指定其长度(数组中元素的数),
例如:
int a[5]; //非法

数组只是声明后,数组中是没有元素值的

数组的初始化

1.Java中的数组必须先初始化,然后才能使用
2.所谓初始化:就是为数组中的数组元素分配内存空间,并为每个数组元素赋值
3.Java中可以使用关键字new创建数组对象,完成静态初始化或动态初始化

动态初始化

**动态初始化:**初始化时只指定数组长度,由系统为数组分配初始值
**格式:**数据类型[] 数组名 = new 数据类型[数组长度];
数组长度其实就是数组中元素的个数
举例:

int arr[] = new int[3];//定义了一个int类型的数组,这个数组中可以存放3个int类型的值

静态初始化

静态初始化:初始化时指定每个数组元素的初始值,由系统决定数组长度
格式:
数据类型[] 数组名 = new 数据类型[]{元素1,元素2,…};
举例:

int arr1[] = new int[]{1,2,3};//定义了一个int类型的数组,这个数组中可以存放3个int类型的值,并且值分别是1,2,3
int arr2[] = {1,2,3};//简化的写法(最常使用)

数组的注意事项

在这里插入图片描述

数组的遍历

在这里插入图片描述
**代码示例:**数组遍历输出

public class Main9 {
    public static void main(String[] args) {
        String books[] = {"Java程序设计基础","Java基础案例教程","Java从入门到实战"};
        System.out.println("books的长度为:" + books.length);//输出books数组的长度,length是数组的表示数组长度属性
        System.out.println("books中的第1本书:" + books[0]);//输出books数组中第一本书:数组中的索引从0开始
        System.out.println("books中的第1本书:" + books[1]);//输出books数组中第二本书
        System.out.println("books中的第1本书:" + books[2]);//输出books数组中第三本书
        System.out.println("---------------------------------");
        for (int i = 0;i< books.length;i++){
            System.out.println("books中的第" + i + "本书:" + books[i]);//使用for循环,遍历books数组
        }
    }
}

运行结果:
在这里插入图片描述

冒泡排序

冒泡排序的基本思路:假设要被排序的数组arr[0…n-1]是垂直放置的,我们将其中的每个元素都看成重量为arr[i]的气泡。那么,根据常识,我们知道重量轻的气泡会向上冒。所以我们制定轻气泡不能在重气泡下的原则。现在,我们从下向上扫描数组arr[n]中的每个元素,凡是发现违反本原则的轻气泡,就使其向上“冒”,反复的执行这个过程,直到所有元素都满足该原则。

冒泡排序原理

在这里插入图片描述

冒泡排序效果

在这里插入图片描述
在这里插入图片描述

示例代码

public class Main10 {
    public static void main(String[] args) {
        int [] numbers = {3,44,38,5,47,15,36,26,27,2,46,4,19,50,48};
        for(int i = 0; i < numbers.length; i++){
            for(int j = 0; j < numbers.length - i - 1; j++){
                if(numbers[j] > numbers[j+1]){
                    int temp = numbers[j];
                    numbers[j] = numbers[j+1];
                    numbers[j+1] = temp;
                }
            }
        }
        System.out.print("从小到大顺序为:");
        for (int a : numbers) {
            System.out.print(a + ",");
        }
    }
}

运行结果:
在这里插入图片描述

多维数组

在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值