java算法小知識練習(二)

  話很少說,直接上題:編程

  題目:兩個乒乓球隊進行比賽,各出三人。甲隊爲a,b,c三人,乙隊爲x,y,z三人。已抽籤決定比賽名單。數組

       有人向隊員打聽比賽的名單。a說他不和x比,c說他不和x,z比,請編程序找出三隊賽手的名單。spa

  思路:建立兩個char型數組,分別存放 a,b,c 和x,y,z.而後分別遍歷 這兩個數組,取出符合條件的值,code

     代碼以下:blog

     

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]);
    }    

  }
}

}

 

  打印結果爲:class

  

對局狀況爲 :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是連着 的,萬一不是連着的呢,這種方法貌似就不可取了,static

  但要是真是爲了解決題而言,第二種不失爲一種好的解決辦法。

相關文章
相關標籤/搜索