综合案例

positive-boy / 2024-08-22 / 原文

练习一:飞机票

需求:

机票价格按照淡季旺季、头等舱和经济舱收费、输入机票原价、月份和头等舱或经济舱。

按照如下规则计算机票价格:旺季(5-10月)头等舱9折,经济舱8.5折,淡季(11月到来年4月)头等舱7折,经济舱6.5折。

代码示例:

package com.java_practice.example;

import java.util.Scanner;

public class Test1 {
    //案例1:卖飞机票
    /*
    机票价格按照淡季旺季、头等舱或经济舱收费、输入机票原价、月份和头等舱或经济舱。

    按照如下规则计算机票价格:旺季(5-10月)头等舱9折,经济舱8.5折,淡季(11月到来年4月)头等舱7折,经济舱6.5折。
     */
    public static void main(String[] args) {
        System.out.println("温馨提示:");
        System.out.println("    "+"头等舱"+":  0");
        System.out.println("    "+"经济舱"+":  1");
        System.out.println("    "+"淡季"+":  11月到来年4月");
        System.out.println("    "+"旺季"+":  5月-10月");
        System.out.println("请输入你乘飞机的月份:");
        Scanner sc=new Scanner(System.in);
        int month=sc.nextInt();
        System.out.println("请输入你是等舱序号:");
        int classSerialNumber=sc.nextInt();
        System.out.println("请输入你的飞机票原价:");
        double ticket_price=sc.nextDouble();
        //调用函数
        double discountedPrices=discountedPrices(month,classSerialNumber,ticket_price);
        System.out.println("打折后的价钱是"+discountedPrices);
    }
    //定义一个方法:用于得出打折后的价钱
    public static double discountedPrices(int month,int classSerialNumber,double ticket_price){
        double discountedFares=1.0;
        if (month>=5 && month<=10){
            if (classSerialNumber==0){
                 discountedFares=0.9;
            }
            else if (classSerialNumber==1){
                 discountedFares=0.85;

            }
        }
        else if (month>=11 || (1<=month && month<=4)){
            if (classSerialNumber==0){
                 discountedFares=0.7;

            }
            else if (classSerialNumber==1){
                 discountedFares=0.65;
            }
        }
        return ticket_price*discountedFares;
    }
}

练习二:打印素数

判断101~200之间有多少个素数,并输出所有素数。

备注:素数就是质数

代码示例:

package com.itheima.test;

public class Test2 {
    public static void main(String[] args) {
        //判断 101 ~ 200 之间有多少个素数,并打印所有素数

        //思路一: 2 ~ 99
        //定义变量i ,赋值100
        //判断i是否为质数

        //定义一个变量用来统计有多少个质数
        int count = 0;
        //外循环:遍历101~200这个范围,依次得到这个范围之内的每一个数字
        for (int i = 101; i <= 200; i++) {
            //i 依次表示循环中的每一个数字
            //继续判断i是否为一个质数
            boolean flag = true;
            //内循环:判断当前数字是否为一个质数。
            for (int j = 2; j < i; j++) {
                //j 表示2~99之间的每一个数字
                if(i % j == 0){
                    flag = false;
                    //跳出单层循环,内循环
                    break;
                }
            }
            if(flag){
                System.out.println("当前数字"+i+"是质数");
                count++;
            }
        }

        System.out.println("一共有" + count + "个质数");

        /* int i = 7;
        boolean flag = true;
        for (int j = 2; j < i; j++) {
            //j 表示2~99之间的每一个数字
            if(i % j == 0){
                flag = false;
                break;
            }
        }
        if(flag){
            System.out.println("当前数字是质数");
        }else{
            System.out.println("当前数字不是一个质数");
        }*/
    }
}

练习三:验证码

需求:

定义方法实现随机产生一个5位的验证码

验证码格式:

长度为5

前四位是大写字母或者小写字母

最后一位是数字

代码示例:

package com.java_practice.example;

import java.util.Random;

public class Test4 {
    public static void main(String[] args) {
        /*
        需求:定义方法实现随机产生一个5位的验证码

        验证码格式:

         长度为5

         前四位是大写字母或者小写字母

         最后一位是数字
         */

        //定义一个数组把所有大小写字母弄进去
        char []  letters=new char[52];
        for (int i = 0; i < letters.length; i++) {
            if (i<=25){
                letters[i]=(char)(97+i);
            }
            else{
                letters[i]=(char)(65+i-26);
            }
        }
        //定义一个变量来存储验证码:
        String yz_code="";
        //调用
        String yz_code2= captcha(letters,yz_code);
        System.out.println(yz_code2);

    }
    //定义一个方法用来得到验证码
    public static String captcha(char list [],String yz_code){
        Random r=new Random();
        for (int i = 0; i < 5; i++) {
            int randomNumbers=r.nextInt(list.length);
            yz_code+=list[randomNumbers];
        }
        yz_code=yz_code+r.nextInt(10);
        return yz_code;
    }
}

练习四:复制数组

需求:

把一个数组中的元素复制到另一个新数组中去。

代码示例:

package com.itheima.test;

public class Test4 {
    public static void main(String[] args) {
        /* 需求:
        把一个数组中的元素复制到另一个新数组中去。*/

        //分析:
        //1.定义一个老数组并存储一些元素
        int[] arr = {1,2,3,4,5};
        //2.定义一个新数组的长度跟老数组一致
        int[] newArr = new int[arr.length];
        //3.遍历老数组,得到老数组中的每一个元素,依次存入到新数组当中
        for (int i = 0; i < arr.length; i++) {
            //i 表示老数组中的索引。新数组中的每一个索引
            //arr[i]  表示老数组中的元素
            newArr[i] = arr[i];
        }

        //4.新数组中已经存满元素了
        for (int i = 0; i < newArr.length; i++) {
            System.out.println(newArr[i]);
        }

    }
}

练习五:评委打分

需求 :

在唱歌比赛中,有6名评委给选手打分,分数范围是[0 - 100]之间的整数。选手的最后得分为:去掉最高分、最低分后的4个评委的平均分,请完成上述过程并计算出选手的得分。

代码示例:

package com.java_practice.example;

import java.util.Scanner;

public class Test6 {
    public static void main(String[] args) {
        /*
         在唱歌比赛中,有6名评委给选手打分,分数范围是[0 - 100]之间的整数。
         选手的最后得分为:去掉最高分、最低分后的4个评委的平均分,
         请完成上述过程并计算出选手的得分。
         */

        //定义一个数组
        int[] score = getScore();
        //获得最大值
        int max=num_max(score);
        //获取最小值
        int min=num_min(score);
        //获取评分平均值
        double average=average(score,max,min);
        //打印平均值
        System.out.println("评分平均值是"+average);


    }

    //定义一个函数用于存储评委评分的方法
    public static int[] getScore() {
        int[] score = new int[6];
        Scanner sc = new Scanner(System.in);
        for (int i = 0; i < score.length; i++) {
            System.out.println("请输入第" + (i + 1) + "位评委的分数  :");
            int score_num = sc.nextInt();
            if (score_num >= 0 && score_num <= 100) {
                score[i] = score_num;
            } else {
                System.out.println("格式错误");
            }
        }
        return score;
    }

    //定义一个方法用于取得最大值
    public static int num_max(int[] list) {
        //假设第一个最大
        int max = list[0];
        for (int i = 0; i < list.length; i++) {
            if (max < list[i]) {
                max = list[i];
            }
        }
        return max;
    }
    //定义一个获取最小值的方法

    public static int num_min(int[] list) {
        //假设第一个最大
        int min = list[0];
        for (int i = 0; i < list.length; i++) {
            if (min > list[i]) {
                min = list[i];
            }
        }
        return min;
    }

    //获取平均值
    public static double average(int[] list,int max,int min) {
        //假设第一个最大
        int sum = 0;
        for (int i = 0; i < list.length; i++) {
            sum = sum + list[i];
        }
        double average=(sum-max-min)/4.0;
        return average;
    }
}

练习六:数字加密

需求:

某系统的数字密码(大于0),比如1983,采用加密方式进行传输。

规则如下:

先得到每位数,然后每位数都加上5 , 再对10求余,最后将所有数字反转,得到一串新数。

举例:

		1	9	8	3
+5		6   14  13  8
%10		6   4   3   8
反转	   8   3   4   6
加密后的结果就是:8346

代码示例:

package com.itheima.test;

public class Test6 {
    public static void main(String[] args) {
        /*
        某系统的数字密码(大于0)。比如1983,采用加密方式进行传输,
        规则如下:
            每位数加上5
            再对10求余,
            最后将所有数字反转,
            得到一串新数。
*/


        //分析:
        //1.把整数里面的每一位放到数组当中
        int[] arr = {1, 9, 8, 3};
        //2.加密
        //每位数加上5
        for (int i = 0; i < arr.length; i++) {
            arr[i] = arr[i] + 5;
        }
        //再对10求余,
        for (int i = 0; i < arr.length; i++) {
            arr[i] = arr[i] % 10;
        }
        //将所有数字反转
        for (int i = 0, j = arr.length - 1; i < j; i++, j--) {
            int temp = arr[i];
            arr[i] = arr[j];
            arr[j] = temp;
        }
        //8 3 4 6 --> 8346
        //3.把数组里面的每一个数字进行拼接,变成加密之后的结果
        int number = 0;
        for (int i = 0; i < arr.length; i++) {
            number = number * 10 + arr[i];
        }
        System.out.println(number);
    }
}

练习六扩展:

package com.itheima.test;

public class Test7 {
    public static void main(String[] args) {
        //需求:
        //把整数上的每一位都添加到数组当中
        //反向推导



        //1.计算出数组的长度
        int number = 12345;
        //定义一个变量临时记录number的值,就是为了第三步的时候再次使用
        int temp = number;
        //定义一个变量进行统计
        int count = 0;
        while(number != 0){
            //每一次循环就去掉右边的一个数字
            number = number / 10;
            //去掉一位计数器就自增一次。
            count++;
        }
        //2.定义数组
        //动态初始化
        int[] arr = new int[count];
        //3.把整数上的每一位都添加到数组当中
        int index = arr.length -1;
        while(temp != 0){//12345
            //获取temp里面的每一位数组
            int ge = temp % 10;
            //再去掉右边的那位数字
            temp = temp / 10;
            //把当前获取到的个位添加到数组当中
            arr[index] = ge;
            index--;
        }
        //验证结果  1  2  3  4 5
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
    }
}
  • 练习六拓展

    package com.java_practice.example;
    
    import java.util.Random;
    
    public class Test7 {
        public static void main(String[] args) {
            //需求:数字加密
            //获取随机数字在1000-9999的随机数字
            Random rand=new Random();
           int randomNumbers=rand.nextInt(9999);
            System.out.println(randomNumbers);
            //调用函数
            int result=encryptTheNumbers(randomNumbers);
            System.out.println(result);
    
    
        }
        //定义一个加密函数
        public static int encryptTheNumbers(int rand_num){
            int result=0;
            while (rand_num!=0){
                //获取个位
                int ge=((rand_num%10)+5)%10;
                //去个位的其他
                rand_num=rand_num/10;
                //控制语句
                result=result*10+ge;
    
    
    
            }
            return result;
        }
    }
    
    /*
    分析:例如12345
    12345 % 10=5;获取个位
    12345/10=1234;获取除了去掉各位的数字
     */
    

练习七:数字解密

把上一题加密之后的数据进行解密

代码示例:

package com.itheima.test;

public class Test8 {
    public static void main(String[] args) {
        /*某系统的数字密码(大于0)。比如1983,采用加密方式进行传输,
        规则如下:
            每位数加上5
            再对10求余,
            最后将所有数字反转,
            得到一串新数。
            按照以上规则进行解密:
            比如1983加密之后变成8346,解密之后变成1983
        */


        //1.定义数组记录解密之后的结果
        int[] arr = {8, 3, 4, 6};
        //2.反转
        for (int i = 0, j = arr.length - 1; i < j; i++, j--) {
            int temp = arr[i];
            arr[i] = arr[j];
            arr[j] = temp;
        }
        //3.由于加密是通过对10取余的方式进行获取的
        //所以在解密的时候就需要判断,0~4之间+10  5~9数字不变
        for (int i = 0; i < arr.length; i++) {
            if (arr[i] >= 0 && arr[i] <= 4) {
                arr[i] = arr[i] + 10;
            }
        }
        //4.每一位减5
        for (int i = 0; i < arr.length; i++) {
            arr[i] = arr[i] - 5;
        }
        //5.获取数组里面的每一位数字拼接成最终的结果
        int number = 0;
        for (int i = 0; i < arr.length; i++) {
            number = number * 10 + arr[i];
        }
        System.out.println(number);




    }
}
  • 拓展

    package com.java_practice.example;
    
    public class Test8 {
        public static void main(String[] args) {
            //数字解密
                  /*某系统的数字密码(大于0)。比如1983,采用加密方式进行传输,
            规则如下:
                每位数加上5
                再对10求余,
                最后将所有数字反转,
                得到一串新数。
                按照以上规则进行解密:
                比如1983加密之后变成8346,解密之后变成1983
            */
            int decrypt=8346;
            int result=DecryptThePassword(decrypt);
            System.out.println(result);
    
        }
        //定义一个解密方法
        public static int DecryptThePassword(int pwd){
            //定义一个变量,用于存储解密之后的密码
            int result=0;
            while (pwd!=0){
                //获取个位
                int ge=((pwd%10)+5)%10;
                //获取除去个位的数字
                pwd=pwd/10;
                //
                result=result*10+ge;
    
            }
            return result;
        }
    }
    /*
    12345 5
    1234 4
     123  3
     12 2
     1  0
     */
    

练习八:抽奖

需求:

一个大V直播抽奖,奖品是现金红包,分别有{2, 588 , 888, 1000, 10000}五个奖金。请使用代码模拟抽奖,打印出每个奖项,奖项的出现顺序要随机且不重复。打印效果如下:(随机顺序,不一定是下面的顺序)

888元的奖金被抽出
588元的奖金被抽出
10000元的奖金被抽出
1000元的奖金被抽出
2元的奖金被抽出

解法一:

package com.itheima.test;

import java.util.Random;

public class Test9 {
    public static void main(String[] args) {
        /* 需求:
        一个大V直播抽奖,奖品是现金红包,分别有{2, 588 , 888, 1000, 10000}五个奖金。
        请使用代码模拟抽奖,打印出每个奖项,奖项的出现顺序要随机且不重复。
        打印效果如下:(随机顺序,不一定是下面的顺序)
            888元的奖金被抽出
            588元的奖金被抽出
            10000元的奖金被抽出
            1000元的奖金被抽出
            2元的奖金被抽出
        */

        //分析:
        //1.定义数组表示奖池
        int[] arr = {2, 588, 888, 1000, 10000};
        //2.定义新数组用于存储抽奖的结果
        int[] newArr = new int[arr.length];
        //3.抽奖
        Random r = new Random();
        //因为有5个奖项,所以这里要循环5次
        for (int i = 0; i < 5; ) {
            //获取随机索引
            int randomIndex = r.nextInt(arr.length);
            //获取奖项
            int prize = arr[randomIndex];
            //判断当前的奖项是否存在,如果存在则重新抽取,如果不存在,就表示是有效奖项
            boolean flag = contains(newArr, prize);
            if(!flag){
                //把当前抽取到的奖项添加到newArr当中
                newArr[i] = prize;
                //添加完毕之后,移动索引
                i++;
            }
        }
        //4.遍历newArr
        for (int i = 0; i < newArr.length; i++) {
            System.out.println(newArr[i]);
        }


    }

    //判断prize在数组当中是否存在
    //存在:true
    //不存在:false
    public static boolean contains(int[] arr,int prize){
        for (int i = 0; i < arr.length; i++) {
            if(arr[i] == prize){
                return true;
            }
        }
        return false;
    }


}

解法二:

package com.itheima.test;

import java.util.Random;

public class Test10 {
    public static void main(String[] args) {
       /* 需求:
        一个大V直播抽奖,奖品是现金红包,分别有{2, 588 , 888, 1000, 10000}五个奖金。
        请使用代码模拟抽奖,打印出每个奖项,奖项的出现顺序要随机且不重复。
        打印效果如下:(随机顺序,不一定是下面的顺序)
            888元的奖金被抽出
            588元的奖金被抽出
            10000元的奖金被抽出
            1000元的奖金被抽出
            2元的奖金被抽出
        */

        //1.把奖池里面的所有奖项打乱顺序
        int[] arr = {2, 588, 888, 1000, 10000};
        Random r = new Random();
        for (int i = 0; i < arr.length; i++) {
            //获取随机索引
            int randomIndex = r.nextInt(arr.length);
            //拿着i跟随机索引randomIndex上的值进行交换
            int temp = arr[i];
            arr[i] = arr[randomIndex];
            arr[randomIndex] = temp;
        }
        //2.遍历奖池,从0索引开始获取每一个奖项
        for (int i = 0; i < arr.length; i++) {
            System.out.println(arr[i]);
        }


    }
}

练习九:双色球

89b23833dt37aa2a2518d268e7843455

代码示例:

package com.itheima.test;

import java.util.Random;
import java.util.Scanner;

public class Test11 {
    public static void main(String[] args) {
        //1.生成中奖号码
        int[] arr = createNumber(); // 123456  7

        System.out.println("=======================");
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }

        System.out.println("=======================");



        //2.用户输入彩票号码(红球 + 蓝球)//654321
        int[] userInputArr = userInputNumber();

        //3.判断用户的中奖情况
        //红球 蓝球
        int redCount = 0;
        int blueCount = 0;

        //判断红球
        for (int i = 0; i < userInputArr.length - 1; i++) {
            int redNumber = userInputArr[i];
            for (int j = 0; j < arr.length - 1; j++) {
                if(redNumber == arr[j]){
                    redCount++;
                    //如果找到了,那么后面的数字就没有必要继续比较了
                    //跳出内循环,继续判断下一个红球号码是否中奖
                    break;
                }
            }
        }

        //判断蓝球
        int blueNumber = userInputArr[userInputArr.length-1];
        if(blueNumber == arr[arr.length - 1]){
            blueCount++;
        }

        //根据红球的个数以及蓝球的个数来判断中奖情况
        if(redCount == 6 && blueCount == 1){
            System.out.println("恭喜你,中奖1000万");
        }else if(redCount == 6 && blueCount == 0){
            System.out.println("恭喜你,中奖500万");
        }else if(redCount == 5 && blueCount == 1){
            System.out.println("恭喜你,中奖3000");
        }else if((redCount == 5 && blueCount == 0) ||  (redCount == 4 && blueCount == 1)){
            System.out.println("恭喜你,中奖200");
        }else if((redCount == 4 && blueCount == 0) ||  (redCount == 3 && blueCount == 1)){
            System.out.println("恭喜你,中奖10");
        }else if((redCount == 2 && blueCount == 1) ||  (redCount == 1 && blueCount == 1)|| (redCount == 0 && blueCount == 1)){
            System.out.println("恭喜你,中奖5");
        }else{
            System.out.println("谢谢参与,谢谢惠顾");
        }

    }

    public static int[] userInputNumber() {
        //1.创建数组用于添加用户购买的彩票号码
        //6个红球 1个蓝球 数组长度:7
        int[] arr = new int[7];

        //2.利用键盘录入让用输入
        Scanner sc = new Scanner(System.in);
        //让用户输入红球号码
        for (int i = 0; i < 6; ) {
            System.out.println("请输入第" + (i + 1) + "个红球号码");
            int redNumber = sc.nextInt();
            //redNumber  在1~33  唯一不重复
            if (redNumber >= 1 && redNumber <= 33) {
                boolean flag = contains(arr, redNumber);
                if (!flag) {
                    //不存在
                    //有效的,可以添加到数组当中
                    arr[i] = redNumber;
                    i++;
                } else {
                    //存在
                    System.out.println("当前红球号码已经存在,请重新输入");
                }
            } else {
                System.out.println("当前红球号码超出范围");
            }
        }

        //让用户输入篮球号码
        System.out.println("请输入篮球号码");
        //1~16
        while (true) {
            int blueNumber = sc.nextInt();
            if (blueNumber >= 1 && blueNumber <= 16) {
                arr[arr.length - 1] = blueNumber;
                break;
            } else {
                System.out.println("当前篮球号码超出范围");
            }
        }
        return arr;

    }


    public static int[] createNumber() {
        //1.创建数组用于添加中奖号码
        //6个红球 1个蓝球 数组长度:7
        int[] arr = new int[7];

        //2.随机生成号码并添加到数组当中
        //红球:不能重复的  1 2 3 4 5 6
        //蓝球:可以跟红球号码重复 5

        //生成红球号码并添加到数组当中
        Random r = new Random();
        for (int i = 0; i < 6; ) {
            //获取红球号码
            int redNumber = r.nextInt(33) + 1;
            boolean flag = contains(arr, redNumber);
            if (!flag) {
                //把红球号码添加到数组当中
                arr[i] = redNumber;
                i++;
            }
        }

        //生成蓝球号码并添加到数组当中
        int blueNumber = r.nextInt(16) + 1;
        arr[arr.length - 1] = blueNumber;
        return arr;
    }

    //用于判断数组在数组中是否存在
    public static boolean contains(int[] arr, int number) {
        for (int i = 0; i < arr.length; i++) {
            if (arr[i] == number) {
                return true;
            }
        }
        return false;
    }
}
  • 第二种方法
package com.java_practice.example;

import java.util.Random;
import java.util.Scanner;

public class Test10 {
    public static void main(String[] args) {
        //双色球彩票:投注号码由6个红色号码和1个蓝色号码组成。
        //红色球号码从1-33中选择;蓝色球号码从1-16中选择。

        //调用函数获取得到的彩票号码
        int[] lottery = getYourTicket();
        for (int i = 0; i < lottery.length; i++) {
            System.out.println(lottery[i]);
        }
        //用于获取红球和篮球个数
        int red_blue_num[]=numberOfBallsObtained(lottery);
        int red_num=red_blue_num[0];
        int blue_num=red_blue_num[1];
        //获取奖励情况
        getTheRewards(red_num,blue_num);
    }

    //定义一个函数用于获取彩票号码
    public static int[] getYourTicket() {
        //定义一个数组用于得到彩票号码
        int[] lottery = new int[7];//动态
        //定义键盘输入对象参数
        Scanner sc = new Scanner(System.in);
        for (int i = 0; i < lottery.length; i++) {
            System.out.println("请输入第" + (i + 1) + "彩票号码  :");
//            int LotteryNumber = sc.nextInt();
            //弄出随机数字
            Random r=new Random();
            int LotteryNumber=r.nextInt(50);
            System.out.println(LotteryNumber);
            //赋值给数组
            lottery[i] = LotteryNumber;

        }
        return lottery;
    }

    //由于1-33是红球范围,篮球号码是1-16中选择,故定义一个比较方法,得到它们分别的个数
    public static int[] numberOfBallsObtained(int[] lottery) {
        int red_num = 0;
        int blue_num = 0;
        for (int i = 0; i < lottery.length; i++) {
            if (i >= 0 && i < lottery.length - 1) {
                if (lottery[i] >= 1 && lottery[i] <= 33) {
                    red_num = red_num + 1;
                }

            } else if (i == lottery.length - 1) {
                if (lottery[i] >= 1 && lottery[i] <= 16) {
                    blue_num = blue_num + 1;
                }

            }

        }
        //定义一个数组用于储存红球个数和篮球个数
        int [] red_blue_num={red_num,blue_num};
        return red_blue_num;

    }

    //定义一个方法用于获取是几等奖
    public static void getTheRewards(int red_num,int blue_num){
        if (red_num==6 && blue_num==1){
            System.out.println("一等奖"+"获取最高1000万元");//1,2,3,4,5,6,17
        }
        if (red_num==6 && blue_num==0){
            System.out.println("二等奖"+"获取最高500万元");
        }
        if (red_num==5 && blue_num==1){
            System.out.println("三等奖"+"获取3000元");
        }
        if ((red_num==5 && blue_num==0) || (red_num==4 && blue_num==1)){
            System.out.println("四等奖"+"获取200元");
        }
        if ((red_num==4 && blue_num==0) || (red_num==3 && blue_num==1)){
            System.out.println("五等奖"+"获取10元");
        }
        if ((red_num==2 && blue_num==1) || (red_num==1 && blue_num==1)){
            System.out.println("六等奖"+"获取5元");
        }
        else {
            System.out.println("谢谢参与,谢谢惠顾");
        }
    }
}

二维数组

1.二维数组的静态初始化

  • 格式:数据类型[] [] 数组名=new 数据类型 [] []{{元素},{元素}}
  • 范例:int [] [] arr=new int[] [] {{11,22},{33,11}};
  • 简化格式 :数据类型 [] [] 数组名 ={{元素1,元素2},{元素1,元素2}};
  • 范例1:int [] [] arr={{11,22},{33,44}};
  • 范例2:int arr [] [] ={{11,22},{44,55}};
  • 元素访问:数组名 [牵引] [牵引];
  • 二维数组遍历:先得到一对数组,再遍历一堆数组获取元素。

2.二维数组的动态初始化

  • 格式:数据类型[] [] 数组名=new 数据类型 [m] [n]
  • m表示这个二维数组,可以存放多少个一堆数组
  • n表示每一个一维数组,可以存放多少个元素。