gzd-123

  话不多说,直接上题:

  题目:两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,乙队为x,y,z三人。已抽签决定比赛名单。

       有人向队员打听比赛的名单。a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单。

  思路:创建两个char型数组,分别存放 a,b,c 和x,y,z.然后分别遍历 这两个数组,取出符合条件的值,

     代码如下:

     

public static void main(String[] args) {

char[] AArray = { \'a\', \'b\', \'c\' };
char[] BArray = { \'x\', \'y\', \'z\' };
for (int i = 0; i < AArray.length; i++) {

  for (int j = 0; j < BArray.length; j++) {
    if((AArray[i]==\'a\' && BArray[j]==\'x\')){
      continue;
    }else if(AArray[i]==\'a\' && BArray[j]==\'y\'){
      continue;
    }else if((AArray[i]==\'c\' && BArray[j]==\'x\')||(AArray[i]==\'c\' && BArray[j]==\'z\')){
      continue;
    }else if((AArray[i]==\'b\' && BArray[j]==\'z\')||(AArray[i]==\'b\' && BArray[j]==\'y\')){
      continue;
    }else{
      System.out.println("对局情况为 :"+AArray[i]+" PK "+BArray[j]);
    }    

  }
}

}

 

  打印结果为:

  

对局情况为 :a PK z
对局情况为 :b PK x
对局情况为 :c PK y

  这种方法就是根据给定的条件排除 他不可能对战的情况,剩下的二就是他对战的情况了,

  然我在网上又看到了一种写法,这种写法貌似看着更简单一点。代码如下:

 

  

public static void main(String[] args) {
        
        char i,j,k;
        for(i=\'x\';i<=\'z\';i++){
            for(j=\'x\';j<=\'z\';j++){
                 if (i != j){
                        for (k = \'x\'; k <= \'z\'; k++) {
                            if (i != k && j != k) {
                                if (i != \'x\' && k != \'x\' && k != \'z\')
                                    System.out.println("A PK "+i+",B PK "+ j+",C PK"+ k);
                            }
                        }
                }
                
            }
            
            
        }
    }

  打印结果为:A PK z,B PK x,C PK y

  这种方法貌似有点投机取巧了,也就是说x,y,z是连着 的,万一不是连着的呢,这种方法貌似就不可取了,

  但要是真是为了解决题而言,第二种不失为一种好的解决办法。

 

分类:

技术点:

相关文章:

  • 2021-09-18
  • 2021-12-14
  • 2021-06-30
  • 2021-09-01
  • 2021-08-07
  • 2021-11-03
  • 2018-03-07
  • 2021-07-14
猜你喜欢
  • 2021-08-07
  • 2021-08-07
  • 2022-01-15
  • 2021-11-09
  • 2021-11-08
  • 2021-11-25
  • 2021-08-07
相关资源
相似解决方案