08-多维数组

08-多维数组

  • 8.1 引言

  • 表或矩阵中的数据可以表示为二维数组。

  • 8.2 二维数组基础
    二维数组中的元素通过行和列的下标来访问。

    • 8.2.1 声明二维数组变量并创建二维数组
      • 下面是声明二维数组的语法:
        数据类型 [][] 数组名;
        //或者
        数据类型 数组名[][];//允许这种方式,但并不推荐使用它。
        
      • 使用matrix[2,1]访问行下标为2、列下标为1的元素是一种常见的错误。在Java中,每个下摆哦必须放在一对方括号中。
    • 8.2.2 获取二维数组的长度
      • 二维数组实际上是一个其中每一个元素都是一个一维数组的数组。
      • x.length表示的是在二维数组中有几个一维数组。x[0].length表示的是这个一维数组的长度。
    • 8.2.3 不规则数组
      • 二维数组中的每一行本身就是一个数组,所以各行的长度就可以不同。这样的数组称作不规则数组。
      • 使用语法new int[5][]创建数组时,必须指定第一个下标。语法new int[][]是错误的。
  • 8.3 处理二维数组

    • 1、使用输入值初始化数组
              int[][] matrix = new int[10][10];
              Scanner input = new Scanner(System.in);
              System.out.println("Enter " + matrix.length + " rows and " + matrix[0].length + " columns: ");
              for (int row = 0;row < matrix.length;row++)
                  for (int column = 0;column < matrix[row].length;column++)
                      matrix[row][column] = input.nextInt();
      
    • 2、使用随机值初始化数组
              int[][] matrix = new int[10][10];
              for (int row = 0;row < matrix.length;row++)
                  for (int column = 0;column < matrix[row].length;column++)
                      matrix[row][column] = (int)(Math.random() * 100);
      
    • 3、打印数组
              int[][] matrix = new int[10][10];
              for (int row = 0;row < matrix.length;row++){
                  for (int column = 0;column < matrix[row].length;column++)
                      System.out.print(matrix[row][column] + " ");
                  System.out.println();
              }
      
      
    • 4、对所有元素求和
              int[][] matrix = new int[10][10];
              int total = 0;
              for (int row = 0; row < matrix.length; row++)
                  for (int column = 0; column < matrix[row].length; column++)
                      total += matrix[row][column];
      
    • 5、按列求和
              int[][] matrix = new int[10][10];
              for (int column = 0;column < matrix.length;column++){
                  int total = 0;
                  for (int row = 0;row < matrix[column].length;row++)
                      total += matrix[row][column];
                  System.out.println("Sum for column " + column + " is " + total);
              }
      
    • 6、哪一行的和最大
              int[][] matrix = new int[10][10];
              int maxRow = 0;
              int indexOfMaxRow = 0;
              
              for (int column = 0;column < matrix[0].length;column++)
                  maxRow += matrix[0][column];
              
              for (int row = 1;row < matrix.length;row++){
                  int totalOfThisRow = 0;
                  for (int column = 0;column < matrix[row].length;column++)
                      totalOfThisRow += matrix[row][column];
                  
                  if (totalOfThisRow > maxRow){
                      maxRow = totalOfThisRow;
                      indexOfMaxRow = row;
                  }
              }
              System.out.println("Row " + indexOfMaxRow + " has the maximum sum of " + maxRow);
      
    • 7、随机打乱
              int[][] matrix = new int[10][10];
              for (int i = 0;i < matrix.length;i++){
                  for (int j = 0;j < matrix[i].length;j++){
                      int i1 = (int)(Math.random() * matrix.length);
                      int j1 = (int)(Math.random() * matrix[i].length);
                      
                      int temp = matrix[i][j];
                      matrix[i][j] = matrix[i1][j1];
                      matrix[i1][j1]= temp;
                  }
              }
      
  • 8.4 将二维数组传递给方法
    将一个数组传递给方法时,数组的引用传递给了方法。

    package chapter08;
    
    import java.util.Scanner;
    
    public class PassTwoDimensionalArray {
        public static void main(String[] args) {
            int[][] m = getArray();
            System.out.println("\nSum of all elements is " + sum(m));
        }
        public static int[][] getArray(){
            Scanner input = new Scanner(System.in);
             int[][] m = new int[3][4];
             System.out.println("Enter " + m.length + " rows and " + m[0].length + " columns: ");
             for (int i = 0;i < m.length;i++)
                 for (int j = 0;j < m[i].length;j++)
                     m[i][j] = input.nextInt();
             return m;
        }
        public static int sum(int[][] m){
            int total = 0;
            for (int row = 0;row < m.length;row++)
                for (int column = 0;column < m[row].length;column++)
                    total += m[row][column];
            return total;
        }
    }
    
    
  • 8.5 示例学习:多选题测验评分

    • 编写一个可以进行多选题测验评分的程序
    • 学生的答案存储在一个二维数组中,正确的答案存储在一个一维数组中。程序给测验评分并显示结果。他将每个学生的答案与正确答案进行比较,统计正确答案的个数,并将其显示出来。
      package chapter08;
      
      public class GradeExam {
          public static void main(String[] args) {
              char[][] answers = {
                      {'A','B','A','C','C','D','E','E','A','D'},
                      {'D','B','A','B','C','A','E','E','A','D'},
                      {'E','D','D','A','C','B','E','E','A','D'},
                      {'C','B','A','E','D','C','E','E','A','D'},
                      {'A','B','D','C','C','D','E','E','A','D'},
                      {'B','B','E','C','C','D','E','E','A','D'},
                      {'B','B','A','C','C','D','E','E','A','D'},
                      {'E','B','E','C','C','D','E','E','A','D'}
              };
              
              char[] keys = {'D','B','D','C','C','D','A','E','D','A'};
              
              for (int i = 0;i < answers.length;i++){
                  int correctCount = 0;
                  for (int j = 0;j < answers[i].length;j++){
                      if (answers[i][j] == keys[j])
                          correctCount++;
                  }
                  System.out.println("Student " + i + "'s correct count is " + correctCount);
              }
          }
      }
      
      
  • 8.6 示例学习:找出距离最近的点对

    • 假设有一个点的集合,找出距离最近的点对问题就是找到两个点,他们到彼此的距离最近。
      package chapter08;
      
      import java.util.Scanner;
      
      public class FindNearestPoints {
          public static void main(String[] args) {
              Scanner input =new Scanner(System.in);
              System.out.print("Enter the number of points: ");
              int numberOfPoints = input.nextInt();
              
              double[][] points = new double[numberOfPoints][2];
              System.out.print("Enter " + numberOfPoints + " points: ");
              for (int i = 0;i < points.length;i++){
                  points[i][0] = input.nextDouble();
                  points[i][1] = input.nextDouble();
              }
              
              int p1 = 0,p2 = 1;
              double shortestDistance = distance(points[p1][0],points[p1][1],points[p2][0],points[p2][1]);
              
              for (int i = 0;i < points.length;i++)
                  for (int j = i + 1;j < points.length;j++){
                      double distance = distance(points[i][0],points[i][1],points[j][0],points[j][1]);
                      
                      if (shortestDistance > distance){
                          p1 = i;
                          p2 = j;
                          shortestDistance = distance;
                      }
                  }
              System.out.println("The closest two point are " + "(" + points[p1][0] + ", " + points[p1][1] + ") and (" + points[p2][0] + ", " + points[p2][1] + ")");
          }
          public static double distance(double x1,double y1,double x2,double y2){
              return Math.sqrt((x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1));
          }
      }
      
      
  • 8.7 示例学习:数独

    • 要解决的问题是检验一个给定的数独解决方案是否正确。
      • 1、检查是否每行都有1到9的数字以及每列都有1到9数字,并且每个小的方块都有1到9的数字。
      • 2、检查每个单元格,每个单元格必须是1到9的数字,并且每个单元格数字在每行、每列以及每个小方盒中都是唯一的。
        package chapter08;
        
        import java.util.Scanner;
        
        public class CheckSudokuSolution {
            public static void main(String[] args) {
                int[][] grid = readASolution();
                System.out.println(isValid(grid) ? "Valid solution" : "Invalid solution");
            }
            public static int[][] readASolution(){
                Scanner input = new Scanner(System.in);
        
                System.out.println("Enter a Sudoku puzzle solution:");
                int[][] grid = new int[9][9];
                for (int i = 0;i < 9;i++)
                    for (int j = 0;j < 9;j++)
                        grid[i][j] = input.nextInt();
                return grid;
            }
            public static boolean isValid(int[][] grid){
                for (int i = 0;i < 9;i++)
                    for (int j = 0;j < 9;j++)
                        if (grid[i][j] < 1 || grid[i][j] > 9 || !isValid(i,j,grid))
                            return false;
                    return true;
            }
            public static boolean isValid(int i,int j,int[][] grid){
                for (int column = 0;column < 9;column++)
                    if (column != j && grid[i][column] == grid[i][j])
                        return false;
                    
                for (int row = 0;row < 9;row++)
                    if (row != i && grid[row][j] == grid[i][j])
                        return false;
                    
                for (int row = (i / 3) *3;row < (i / 3) * 3 + 3;row++)
                    for (int col = (j / 3) * 3;col < (j / 3) * 3 + 3;col++)
                        if (!(row == i && col == j) && grid[row][col] == grid[i][j])
                            return false;
                return true;
            }
        }
        
        
  • 8.8 多维数组
    二维数组由一个一维数组的数组组成,而一个三维数组可以认为是由一个二维数组的数组所组成。

    • 8.8.1 示例学习:每日温度和湿度
      • 假设气象站每天每小时都会记录湿度和温度,并且将过去十天的数据都存储在一个名为Weather.txt的文本文件中。文件中的每一行包含四个数字,分别表明天、小时、温度和湿度。你的任务是编写程序,静思园10天的日均温度和日均湿度。可以使用输入重定向来读取文件。
        package chapter08;
        
        import java.util.Scanner;
        
        public class Weather {
            public static void main(String[] args) {
                final int NUMBER_OF_DAYS = 10;
                final int NUMBER_OF_HOURS = 24;
                double[][][] data = new double[NUMBER_OF_DAYS][NUMBER_OF_HOURS][2];
        
                Scanner input = new Scanner(System.in);
                for (int k = 0;k < NUMBER_OF_DAYS * NUMBER_OF_HOURS;k++){
                    int day = input.nextInt();
                    int hours =input.nextInt();
                    double temperature = input.nextDouble();
                    double humidity = input.nextDouble();
                    data[day - 1][hours - 1][0] = temperature;
                    data[day - 1][hours - 1][1] = humidity;
                }
        
                for (int i = 0;i < NUMBER_OF_DAYS;i++){
                    double dailyTemperatureTotal = 0,dailyHumidityTotal = 0;
                    for (int j = 0;j < NUMBER_OF_HOURS;j++){
                        dailyTemperatureTotal += data[i][j][0];
                        dailyHumidityTotal += data[i][j][1];
                    }
        
                    System.out.println("Day " + i + "'s average temperature is " + dailyTemperatureTotal / NUMBER_OF_HOURS);
                    System.out.println("Day " + i + "'s average humidity is " + dailyHumidityTotal / NUMBER_OF_HOURS);
                }
            }
        }
        
        
      • 可以使用下面的命令来运行这个程序:
        java Weather < Weather.txt
        
    • 8.8.2 示例学习:猜生日
      package chapter08;
      
      import java.util.Scanner;
      
      public class GuessBirthdayUsingArray {
          public static void main(String[] args) {
              int day = 0 ;
              int answer;
              int[][][] dates = {
                      {
                              {1,3,5,7},
                              {9,11,13,15},
                              {17,19,21,23},
                              {25,27,29,31}
                      },
                      {
                              {2,3,6,7},
                              {10,11,14,15},
                              {18,19,22,23},
                              {26,27,30,21}
                      },
                      {
                              {4,5,6,7},
                              {12,13,14,15},
                              {20,21,22,23},
                              {28,29,30,31}
                      },
                      {
                              {8,9,10,11},
                              {12,13,14,15},
                              {24,25,26,27},
                              {28,29,30,31}
                      },
                      {
                              {16,17,18,19},
                              {20,21,22,23},
                              {24,25,26,27},
                              {28,29,30,31}
                      }
              };
      
              Scanner input = new Scanner(System.in);
              for (int i = 0;i < 5;i++){
                  System.out.println("Is your birthday in set " + (i + 1) + "?");
                  for (int j = 0;j < 4;j++){
                      for (int k = 0;k < 4;k++)
                          System.out.printf("%4d",dates[i][j][k]);
                      System.out.println();
                  }
                  
                  System.out.print("\nEnter 0 for No and 1 for Yes: ");
                  answer = input.nextInt();
                  if (answer == 1)
                      day += dates[i][0][0];
              }
              System.out.println("Your birthday is " + day);
          }
      }
      
      
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,335评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,895评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,766评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,918评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,042评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,169评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,219评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,976评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,393评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,711评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,876评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,562评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,193评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,903评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,699评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,764评论 2 351