java基础(六):数组

数组

作用:储存同种数据类型的多个值。 
概念:可以存储同一种数据类型多个元素的集合,可以看作一个容器(基本数据类型,应用数据类型) 
定义格式 
数据类型[] 数组名 = new 数据类型[数组的长度];- 
int[] arr = int[6].——(动态初始化 只指定长度,由系统给出初始化值) 
数组初始化河运行的内存结果图 
数组初始化和运行的内存结果图 
常见异常 
* a:ArrayIndexOutOfBoundsException:数组索引越界异常 
* 原因:你访问了不存在的索引。 
* b:NullPointerException:空指针异常 
* 原因:数组已经不在指向堆内存了。而你还用数组名去访问元素。 
* int[] arr = {1,2,3}; 
* arr = null; 
* System.out.println(arr[0]);

*

数组遍历:

  • 就是依次输出数组中的每一个元素。 
    • 数组的属性:arr.length数组的长度
    • 数组的最大索引:arr.length - 1; 
      public static void print(int[] arr) { 
      for (int i = 0;i < arr.length ;i++ ) { 
      System.out.print(arr[i] + ” “); 

      }

数组获取最值(获取数组中的最大值最小值)

public static int getMax(int[] arr) {
            int max = arr[0];
            for (int i = 1;i < arr.length ;i++ ) {          //从数组的第二个元素开始遍历
                if (max < arr[i]) {                         //如果max记录的值小于的数组中的元素
                    max = arr[i];                           //max记录住较大的
                }
            }
            return max;
        }

数组元素反转(就是把元素对调)

public static void reverseArray(int[] arr) {
            for (int i = 0;i < arr.length / 2 ; i++) {
                //arr[0]和arr[arr.length-1-0]交换
                //arr[1]和arr[arr.length-1-1]交换
                //arr[2]和arr[arr.lentth-1-2]
                //...
                int temp = arr[i];
                arr[i] = arr[arr.length-1-i];
                arr[arr.length-1-i] = temp;
            }
        }

数组查表法(根据键盘录入索引,查找对应星期)

public static char getWeek(int week) {
            char[] arr = {' ','一','二','三','四','五','六','日'};     //定义了一张星期表
            return arr[week];                                           //通过索引获取表中的元素
        }

数组元素查找(查找指定元素第一次在数组中出现的索引)

public static int getIndex(int[] arr,int value) {
            for (int i = 0;i < arr.length ;i++ ) {              //数组的遍历
                if (arr[i] == value) {                          //如果数组中的元素与查找的元素匹配
                    return i;
                }
            }
            return -1;
        } 

二维数组

格式:int[][] arr = new int[3][2]; 
int[][] arr = new int[3][]; 
int[][] arr = {{1,2,3},{4,5},{6,7,8,9}}; 
二维数组结构图 
这里写图片描述

二维数组遍历

  • 外循环控制的是二维数组的长度,其实就是一维数组的个数。

    • 内循环控制的是一维数组的长度。

      int[][] arr = {{1,2,3},{4,5},{6,7,8,9}};
      
      for (int i = 0;i < arr.length ;i++ ) {          //获取到每个二维数组中的一维数组
          for (int j = 0;j < arr[i].length ;j++ ) {   //获取每个一维数组中的元素
              System.out.print(arr[i][j] + " ");
          }
          System.out.printn();
      }
      }
      

二维数求和

需求:公司年销售额求和
    某公司按照季度和月份统计的数据如下:单位(万元)
    第一季度:22,66,44
    第二季度:77,33,88
    第三季度:25,45,65
    第四季度:11,66,99
    int[][] arr = {{22,66,44},{77,33,88},{25,45,65},{11,66,99}};
    int sum = 0;                                    //定义变量,记录每次相加的结果
    for (int i = 0;i < arr.length ;i++ ) {          //获取每一个一维数组
        for (int j = 0;j < arr[i].length ;j++ ) {   //获取每一个一维数组中的元素
            sum = sum + arr[i][j];                  //累加
        }
    }
    System.out.println(sum);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值