話很少說,直接上題:編程
題目:兩個乒乓球隊進行比賽,各出三人。甲隊爲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
但要是真是爲了解決題而言,第二種不失爲一種好的解決辦法。