• 第七届蓝桥杯javaB组真题解析-分小组(第四题)


    题目

     1 /*
     2 分小组
     3 
     4 9名运动员参加比赛,需要分3组进行预赛。
     5 有哪些分组的方案呢?
     6 
     7 我们标记运动员为 A,B,C,... I
     8 下面的程序列出了所有的分组方法。
     9 
    10 该程序的正常输出为:
    11 ABC DEF GHI
    12 ABC DEG FHI
    13 ABC DEH FGI
    14 ABC DEI FGH
    15 ABC DFG EHI
    16 ABC DFH EGI
    17 ABC DFI EGH
    18 ABC DGH EFI
    19 ABC DGI EFH
    20 ABC DHI EFG
    21 ABC EFG DHI
    22 ABC EFH DGI
    23 ABC EFI DGH
    24 ABC EGH DFI
    25 ABC EGI DFH
    26 ABC EHI DFG
    27 ABC FGH DEI
    28 ABC FGI DEH
    29 ABC FHI DEG
    30 ABC GHI DEF
    31 ABD CEF GHI
    32 ABD CEG FHI
    33 ABD CEH FGI
    34 ABD CEI FGH
    35 ABD CFG EHI
    36 ABD CFH EGI
    37 ABD CFI EGH
    38 ABD CGH EFI
    39 ABD CGI EFH
    40 ABD CHI EFG
    41 ABD EFG CHI
    42 ..... (以下省略,总共560行)。
    43 
    44 public class A
    45 {
    46     public static String remain(int[] a)
    47     {
    48         String s = "";
    49         for(int i=0; i<a.length; i++){
    50             if(a[i] == 0) s += (char)(i+'A');
    51         }    
    52         return s;
    53     }
    54     
    55     public static void f(String s, int[] a)
    56     {
    57         for(int i=0; i<a.length; i++){
    58             if(a[i]==1) continue;
    59             a[i] = 1;
    60             for(int j=i+1; j<a.length; j++){
    61                 if(a[j]==1) continue;
    62                 a[j]=1;
    63                 for(int k=j+1; k<a.length; k++){
    64                     if(a[k]==1) continue;
    65                     a[k]=1;
    66                     System.out.println(__________________________________);  //填空位置
    67                     a[k]=0;
    68                 }
    69                 a[j]=0;
    70             }
    71             a[i] = 0;
    72         }
    73     }
    74     
    75     public static void main(String[] args)
    76     {
    77         int[] a = new int[9];        
    78         a[0] = 1;
    79         
    80         for(int b=1; b<a.length; b++){
    81             a[b] = 1;
    82             for(int c=b+1; c<a.length; c++){
    83                 a[c] = 1;
    84                 String s = "A" + (char)(b+'A') + (char)(c+'A');
    85                 f(s,a);
    86                 a[c] = 0;
    87             }
    88             a[b] = 0;
    89         }
    90     }
    91 }
    92 
    93 仔细阅读代码,填写划线部分缺少的内容。
    94 
    95 注意:不要填写任何已有内容或说明性文字。
    96 */

    答案

    s + " "+ (char)(i+'A') + (char)(j+'A') + (char)(k+'A') + " " + remain(a)

     

    代码

     1 public class Main
     2 {
     3     public static String remain(int[] a)
     4     {
     5         String s = "";
     6         for(int i=0; i<a.length; i++){
     7             if(a[i] == 0) s += (char)(i+'A');
     8         }
     9         return s;
    10     }
    11     
    12     public static void f(String s, int[] a)
    13     {
    14         for(int i=0; i<a.length; i++){
    15             if(a[i]==1) continue;
    16             a[i] = 1;
    17             for(int j=i+1; j<a.length; j++){
    18                 if(a[j]==1) continue;
    19                 a[j]=1;
    20                 for(int k=j+1; k<a.length; k++){
    21                     if(a[k]==1) continue;
    22                     a[k]=1;
    23                     System.out.println(s + " "+ (char)(i+'A') + (char)(j+'A') + (char)(k+'A') + " " + remain(a));  //填空位置
    24                     a[k]=0;
    25                 }
    26                 a[j]=0;
    27             }
    28             a[i] = 0;
    29         }
    30     }
    31     
    32     public static void main(String[] args)
    33     {
    34         int[] a = new int[9];        
    35         a[0] = 1;
    36         
    37         for(int b=1; b<a.length; b++){
    38             a[b] = 1;
    39             for(int c=b+1; c<a.length; c++){
    40                 a[c] = 1;
    41                 String s = "A" + (char)(b+'A') + (char)(c+'A');
    42                 f(s,a);
    43                 a[c] = 0;
    44             }
    45             a[b] = 0;
    46         }
    47     }
    48 }

    注释

      就这个“九个人分三组” 分法来说,在我反复思考,百度之后,发现这个题给出的分组答案竟然是错误的,正确的分组方法应该有280种(用高中数学方法可以算出,或者你可以百度),而不是560种,在我研究了一下代码的输出情况发现,每一种情况都输出了两次,题目的要求是没有顺序分成三组,但是就题目给出的算法,每一种情况,都会有两组是有先后顺序的。

      吐槽完毕然后来说这个题目

      题目给出的代码思路是抓住 ‘A’ 不放,先找出所有的可以由‘A’组成的,单个小组项,然后从剩下的六个人中,随机抽三个人,组成一组,然后结合剩下的三个人,一起构成一种情况输出来,到这里你大概就能明白过来这个代码就这个题目而言到底是错在哪儿了,是因为在确定完‘A’所在的小组项之后,剩下的六个人中是随机抽取三个人的,所以随机抽取三个人,和剩下的三个人,就有个先后顺序了! 到这里大家明白了吧。

      继续讲解这个代码,这个思路是全排列的递归方法的一个针对题目的一个转化,先声明一个数组用作标记,用来标记本次的循环小节中先后抽取了谁,每一个循环小节都会标记一个人(a[b]=1或者a[c]=1),然后在本次循环结束时,在把标记清除,开始下一循环小节

     1     public static void main(String[] args)
     2     {
     3         int[] a = new int[9];        
     4         a[0] = 1;
     5         
     6         for(int b=1; b<a.length; b++){
     7             a[b] = 1;
     8             for(int c=b+1; c<a.length; c++){
     9                 a[c] = 1;
    10                 String s = "A" + (char)(b+'A') + (char)(c+'A');
    11                 f(s,a);
    12                 a[c] = 0;
    13             }
    14             a[b] = 0;
    15         }
    16     }

      这个就是第一步 确定带‘A’项,并把第一项存储到一个字符串中,外层for循环是用来标记带‘A’项中的第二个人,内层是标记第三个人。 然后开始到第二步:从六个人中抽取三个人(f(s,a)

     1     public static void f(String s, int[] a)
     2     {
     3         for(int i=0; i<a.length; i++){
     4             if(a[i]==1) continue;
     5             a[i] = 1;
     6             for(int j=i+1; j<a.length; j++){
     7                 if(a[j]==1) continue;
     8                 a[j]=1;
     9                 for(int k=j+1; k<a.length; k++){
    10                     if(a[k]==1) continue;
    11                     a[k]=1;
    12                     System.out.println(s + " "+ (char)(i+'A') + (char)(j+'A') + (char)(k+'A') + " " + remain(a));  //填空位置
    13                     a[k]=0;
    14                 }
    15                 a[j]=0;
    16             }
    17             a[i] = 0;
    18         }
    19     }

      这个方法中三层for循环用来确定六个人中被随机抽取的三个人,由外到内依次是,第一个,第二个,第三个,并做上标记 所以中间的三个字母可以表示为

    (char)(i+'A') + (char)(j+'A') + (char)(k+'A') 

      还有最后一个方法 remain() 方法

    1     public static String remain(int[] a)
    2     {
    3         String s = "";
    4         for(int i=0; i<a.length; i++){
    5             if(a[i] == 0) s += (char)(i+'A');
    6         }
    7         return s;
    8     }

      用于判断没有被标记的剩下三个人是谁,然后用字符串存储并返回。

      到次大家应该可以弄明白整个代码了吧 :)

  • 相关阅读:
    day-11 python自带库实现2层简单神经网络算法
    day-10 sklearn库实现SVM支持向量算法
    day-9 sklearn库和python自带库实现最近邻KNN算法
    day-8 python自带库实现ID3决策树算法
    day-7 sklearn库实现ID3决策树算法
    day-6 机器学习概念及应用
    day-5 python协程与I/O编程深入浅出
    day-4 python多进程编程知识点汇总
    day-3 python多线程编程知识点汇总
    3、TensorFlow基础(一) 设计思想与编程模型
  • 原文地址:https://www.cnblogs.com/loveluking/p/6372671.html
Copyright © 2020-2023  润新知