java3.数组

本文详细介绍了Java中的数组,包括一维数组和多维数组的定义、使用及初始化。讲解了数组的长度、元素访问、引用类型以及数组操作中的常见算法,如排序。还提到了Java中的Arrays工具类用于数组操作,并讨论了数组操作中可能遇到的异常,如空指针和越界。此外,文中包含数组相关的编程练习,如杨辉三角的实现。
摘要由CSDN通过智能技术生成

3.1数组的概述
数组:是多个相同的数据按一定的顺序排列的集合,并使用一个名字命名,并通过编号的方式对这些数据进行统一管理.
数组的常见概念:数组名,下标,元素,数组的长度
数组本身是引用数据类型,而数组中的元素可以是任何数据类型,包括
基本数据类型引用数据类型
创建数组对象会在内存中开辟一整块连续的空间,而数组名中引用的是这块连续空间的首地址
数组的长度一旦确定,就不能修改
我们可以直接通过下标(或索引)的方式调用指定位置的元素,速度很快
数组的分类:
按照维度:一维数组、二维数组、三维数组、…
按照元素的数据类型分:基本数据类型元素的数组、引用数据类型元素的数组(即对象数组)

3.2一维数组的使用
在这里插入图片描述
定义并用运算符new为之分配空间后,才可以引用数组中的每个元素;
数组元素的引用方式:数组名[数组元素下标]  数组元素下标可以是整型常量或整型表达式。如a[3] , b[i] , c[6*i];
数组元素下标从0开始;长度为n的数组合法下标取值范围: 0 —>n-1;如int a[]=new
int[3]; 可引用的数组元素为a[0]、a[1]、a[2]
每个数组都有一个属性length指明它的长度,例如:a.length 指明数组a的长度(元素个数)
数组一旦初始化,其长度是不可变的

	数组是引用类型,它的元素相当于类的成员变量,因此数组一经分配空间,其中的每个元素也被按照成员变量同样的方式被隐式初始化。

对于基本数据类型而言,默认初始化值各有不同
对于引用数据类型而言,默认初始化值为null(注意与0不同!)

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

int[] arr1 = new int[4]; //在宅中存储arr1指向new对象的第一个地址
//int默认值为0
arr1[0] = 10;//为第一个位置赋值
arr1[2] = 20;//为第三个位置赋值
String[] arr2 = new String[3]; //寨中存储arr2,指向新对象的第一个地址,String为引用类型,默认值为null
arr2[1] = “刘杰”;//为第二个地址赋值
arr2 = new String[5]; //为arr2重新开辟地址,指向第一个字符串的地址

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

package arraytest;

import java.util.Scanner;

/**
 * describe:
 *
 * @author suoliang
 * @create 2021-06-20:31
 */
public class UseTest2 {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入学生的人数:");
        int num = scanner.nextInt();
        int[] scores = new int[5];
        System.out.println("请输入" + num + "个成绩:");
        int max_score = 0;
        int id;
        for (int i = 0; i < num; i++){
            int sco = scanner.nextInt();
            scores[i] = sco;
            if (scores[i] > max_score){
                max_score = scores[i];
                id = i;
            }
        }
        System.out.println("最高分是" + max_score);
        for (int i = 0; i < num; i++){
            if (scores[i] >= max_score - 10){
                System.out.println("student " + i + "score is " + scores[i] + "grade is A");
            }
            else if (scores[i] >= max_score - 20){
                System.out.println("student " + i + "score is " + scores[i] + "grade is B");
            }
            else if (scores[i] >= max_score - 30){
                System.out.println("student " + i + "score is " + scores[i] + "grade is C");
            }else {
                System.out.println("student " + i + "score is " + scores[i] + "grade is D");
            }
        }


    }
}

3.3多维数组的使用
Java 语言里提供了支持多维数组的语法。
如果说可以把一维数组当成几何中的线性图形,
那么二维数组就相当于是一个表格,像右图Excel
中的表格一样。
对于二维数组的理解,我们可以看成是一维数组
array1又作为另一个一维数组array2的元素而存
在。其实,从数组底层的运行机制来看,其实没
有多维数组。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

//创建一个4行未知列的二维数组,此时每行都是一个一维数组,引用类型,所以默认值为null
int[][] arr1 = new int[4][];
//第2行有三个元素
arr1[1] = new int[]{1,2,3};
//第3行有四个元素,为int型的基本数据类型,默认为0
arr1[2] = new int[4];
//第三行第二列的值改为30
arr1[2][1] = 30;

在这里插入图片描述

int[][] arr4 = new int[3][];
sysout(arr4[0]);//null
sysout(arr4[0][0]);//报错 :原因:arr4还没有new出来
arr4[0] = new int[3];
arr4[0][1] = 5;
arr4[1] = new int[]{1,2};

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

int[][] arr1 = new int[4][];//4行未知列
arr1[0] = new int[3];//第一行3个元素
arr1[1] = new int[]{1,2,3};//第二行三个元素
arr1[0][2] = 5;
arr1 = new int[2][];//arr1指向了新开辟的地址

练习:获取元素中所有的值:使用内外两层循环

声明:int[] x,y[]; 在给x,y变量赋值以后,以下选项允许通过编译的是:
a ) x[0] = y; no:x[0]基本数据类型,y为二维数据
b) y[0] = x; yes:y[0]为一维数组,x一维数组
c) y[0][0] = x; no:y[0][0]基本数据类型
d) x[0][0] = y; no:x[0][0]异常
e) y[0][0] = x[0]; yes:y[0][0],x[0]基本数据类型
f) x = y; no:一维二维
提示:
**一维数组:int[] x 或者int x[] 
二维数组:int[][] y 或者 int[] y[] 或者 int y[][]**

练习:打印杨辉三角
在这里插入图片描述

【提示】
1. 第一行有 1 个元素, 第 n 行有 n 个元素
2. 每一行的第一个元素和最后一个元素都是 1
3. 从第三行开始, 对于非第一个元素和最后一个元
素的元素。即:
yanghui[i][j] = yanghui[i-1][j-1] + yanghui[i-1][j];

3.4数组中涉及到的常见的算法
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

int[] array1, array2;
array1 = new int[] { 2, 3, 5, 7, 11, 13, 17, 19 };
array2 = array1;//直接等于两个指向同一个地址,会一起变换
for (int i = 0; i < array2.length; i++) {
if (i % 2 == 0) {
array2[i] = i; } }

复制实现方法
在这里插入图片描述
二分法:适合按大小顺序排的数组找最大最小值
在这里插入图片描述
冒泡排序:每一轮找到最大的放最后面
在这里插入图片描述
快速排序:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
3.5Arrays工具类的使用
在这里插入图片描述

import java.util.Arrays;
public class SortTest {
public static void main(String[] args) {
	int [] numbers = {5,900,1,5,77,30,64,700};
	Arrays.sort(numbers);
	for(int i = 0; i < numbers.length; i++){
	System.out.println(numbers[i]); } } }

3.6数组中常见的异常
1.空指针
2.越界
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值