andy6804tw
4/7/2017 - 4:03 AM

http://e-tutor.itsa.org.tw/e-Tutor/mod/programming/view.php?id=3529 這題就只是考陣列而已簡單來說找出每位地差集1代表沒興趣0表示有興趣,4個迴圈下去跑組合,每次還需要盤段是否為"愉快"的狀態(表1234每位都有

http://e-tutor.itsa.org.tw/e-Tutor/mod/programming/view.php?id=3529

這題就只是考陣列而已簡單來說找出每位地差集1代表沒興趣0表示有興趣,4個迴圈下去跑組合,每次還需要盤段是否為"愉快"的狀態(表1234每位都有分配到沒重複搶人狀況發生),結束時必須在換一行

import java.util.*;

public class Main {

	public static void main(String[] args) {
		Scanner scn = new Scanner(System.in);
		int n=scn.nextInt();
		while(n--!=0){
			int arr[][]=new int[4][4];
			for(int i=0;i<4;i++){
				scn.next();
				while(true){
					int num=scn.nextInt();
					if(num==0)
						break;
					else
						arr[i][num-1]=1;
				}
			}
			int count=0;
			for(int i=0;i<4;i++){
				if(arr[0][i]==1)
					continue;
				for(int j=0;j<4;j++){
					if(arr[1][j]==1)
						continue;
					for(int k=0;k<4;k++){
						if(arr[2][k]==1)
							continue;
						for(int l=0;l<4;l++){
							if(arr[3][l]==1)
								continue;
							else{
								int temp[]=new int[4];
								temp[i]=1;temp[j]=1;temp[k]=1;temp[l]=1;
								if(temp[0]+temp[1]+temp[2]+temp[3]==4){
									if(count==0)
										System.out.println("ABCD");
									System.out.println((i+1)+""+(j+1)+""+(k+1)+""+(l+1));
									count++;
								}
							}
								
						}
					}
				}
			}
			if(count==0)
				System.out.println("No Solution");
			System.out.println();
		}
	}
	/*題目:C_AR61-易 配對
    作者:1010
    時間:西元 2017 年 4 月 7日*/
}