数组

基础题目

第一题:需求实现

  • 模拟大乐透号码:

    • 一组大乐透号码由10个1-99之间的数字组成

    • 定义方法,打印大乐透号码信息

  • 代码实现,效果如图所示:

  • 开发提示:

    • 使用数组保存录入的号码

  • 参考答案:

 public class Test1 {
        public static void main(String[] args) {
            int[] arr  = {10,20,30,40,50, 60,66,70,80,99};
            printNum(arr);
        }
    
        public static void printNum(int[] arr) {
            System.out.println("您的大乐透号码为:");
            for (int i = 0; i < arr.length; i++) {
                System.out.print(arr[i]+" ");
            }
        }
    }

  

第二题:需求实现

  • 打印扑克牌.

  • 代码实现,效果如图所示:

  • 开发提示:

    • 使用两个字符串数组,分别保存花色和点数

 public class Test2 {
        public static void main(String[] args) {
            // 花色数组
            String[] hs  = {"黑桃","红桃","梅花","方片"};
            // 点数数组
            String[] ds = {"A","2","3","4", "5","6","7","8","9","10","J","Q","K"};
            printCard(hs,ds);
        }
        public static void printCard(String[] hs ,String[] ds){
            for (int hs_index = 0; hs_index < hs.length; hs_index++) {
                for (int ds_index = 0; ds_index < ds.length; ds_index++) {
                    // 拼接字符串
                    System.out.print(  hs[hs_index] + ds[ds_index]+" ");
                }
                // 输出换行
                System.out.println();
            }
        }
    }

 

第三题:需求实现

  • 模拟在一副牌中,抽取第1张,第5张,第50张扑克牌。

  • 代码实现,效果如图所示:

  • 参考答案:


public class Test3 {
        public static void main(String[] args) {
            // 获取所有扑克牌
            String[] puke = getPuke();
    
            // 抽取指定的三种扑克牌
            int num1 = 1;
            int num2 = 5;
            int num3 = 50;
            String[] pk3 = get3(puke , num1 ,num2,num3);
            // 打印抽取的牌
            for (int i = 0; i < pk3.length; i++) {
                System.out.print(pk3[i] + " ");
            }
        }
    
        private static String[] getPuke() {
    
            String[] colors={"黑色","红桃","梅花","方块"};
            String[] nums={"A","2","3","4","5","6","7","8","9","10","J","Q","K"};
    
            String[] puke = new String[54];
            int index = 0;
            for (int i = 0; i < colors.length; i++) {
                for (int j = 0; j < nums.length; j++) {
                    puke[index] = colors[i]+nums[j];
                    index ++;
                }
            }
            puke[52] = "小王";
            puke[53] = "大王";
    
            return puke;
    
        }
    
        public static String[] get3(String[] puke, int i, int i2, int i3) {
            String[] pk3 = new String[3];
            pk3[0] = puke[i - 1];
            pk3[1] = puke[i2 - 1];
            pk3[2] = puke[i3 - 1];
            return pk3;
        }
    }

 

第四题:需求实现

  • 统计字符

    • 字符数组:{'a','l','f','m','f','o','b','b','s','n'}

    • 定义printCount方法,统计每个字符出现的次数并打印到控制台。

  • 代码实现,部分效果如图所示:

     

     

     

  • 开发提示:

    • 将数字强制转换,根据ASCII码表转换为字符。

    • 可以定义长度26的数组,每个元素,对应去保存每种字符的出现次数,比如0索引保存a的次数,1索引保存b的次数,以此类推。

  • 参考答案:


     public class Test4 {
          public static void main(String[] args) {
              //  获取长度100的字符数组
              char[] charArray = {'a','l','f','m','f','o','b','b','s','n'};
              //  统计字符数组中字母出现次数
              printCount(charArray);
          }
          public static void printCount(char[] charArray) {
              int[] count= new int[26];
              // 对应保存字母出现的次数
              for (int i = 0; i < charArray.length; i++) {
                  int c  = charArray[i];
                  count[c- 97]++;
              }
              // 打印字母和次数
              for (int i = 0, ch = 97; i < count.length; i++, ch++) {
                  if (count[i] != 0 ) {
                      System.out.println((char) ch + "--" + count[i]);
                  }
              }
          }
      }
    

      

第五题:需求实现

  • 统计高于平均分的分数有多少个。

    • 定义数组[95, 92, 75, 56, 98, 71, 80, 58, 91, 91]。

    • 定义getAvg方法,获取一个数组中的平均数

  • 代码实现,效果如图所示:

  • 参考答案:


     public class Test5 {
          public static void main(String[] args) {
              // 获取随机分数
              int[] score = {95, 92, 75, 56, 98, 71, 80, 58, 91, 91};
              // 获取平均分
              int avg = getAvg(score);
              // 定义计数的变量
              int count = 0 ;
              for (int i = 0; i < score.length; i++) {
                  if (score[i] > avg){
                      count++;
                  }
              }
              System.out.println("高于平均分:"+avg+" 的 个数有" + count+" 个");
          }
          // 获取平均分的方法
          public static int getAvg(int[] arr) {
              int sum = 0;
              for (int i = 0; i < arr.length; i++) {
                  sum += arr[i];
              }
              return sum / arr.length;
          }  
      }

     

第六题:需求实现

  • 定义sym方法,判断数组中的元素值是否对称.

  • 代码实现,效果如图所示:

  • 开发提示:

    • 数组中元素首尾比较。

  • 参考答案:

     public class Test6 {
          public static void main(String[] args) {
              int[] arr = {1,2,3,4,3,2,1};
              System.out.println(Arrays.toString(arr) +" 是否对称:" +sym(arr) );
    ​
              int[] arr2 = {1,2,3,4,5,2,1};
              System.out.println(Arrays.toString(arr2) +" 是否对称:" +sym(arr2) );
          }
    ​
          public static boolean sym(int[] arr) {
              /*
              start : 数组头
              end :数组尾 
               */
              for (int start = 0 , end = arr.length -1 ; start <= end; start++, end--) {
                  // 如果两端一旦有元素不等,就返回false
                  if (arr[start] != arr[end]) {     
                      return false;
                  }
              }
              return true;
          }
      }

     

第七题:需求实现

  • 定义equals方法,比较数组内容是否完全一致。

  • 代码实现,效果如图所示:

  • 开发提示:

    • 长度一致,内容一致,定义为完全一致。

  • 参考答案:

 public class Test7 {
      public static void main(String[] args) {
​
          int[] arr = {1,2,3,4,3,2,1};
          int[] arr2 = {1,2,3,4,3,2,1};
          System.out.println(" 是否一致:" +equals(arr ,arr2) );
​
      }
      //  比较数组的内容
      public static boolean equals(int[] arr1, int[] arr2) {
    // 长度不同,返回false
          if (arr1.length != arr2.length) {
              return false;
          }
    
    //
          for (int i = 0; i < arr1.length; i++) {
              // arr1[i] 和 arr2[i]比较
              /*
               * 所有元素都相同才相同,也就是只要有一个不同,这两个数组就是不同
               */
              if (arr1[i] != arr2[i]) {
                  return false;
              }
          }
          return true;
      }
  }

  

posted @ 2020-08-11 22:23  极地阳光-ing  阅读(175)  评论(0编辑  收藏  举报