1 import java.util.Scanner; 2 public class Test5 { 3 public static int res=1061109567; 4 public static int n,m; 5 public static int[][] gra; 6 public static int[][] cun; 7 public static int[] cnt; 8 public static void solve(int id,int num){ //id表示學生,num表示當前考場的編號 9 if(num>=res){ //當現在安排的數量已經大於了最小的教室數量的話,返回 10 return; 11 } 12 if(id>n){ //安排的學生已經大於所有的學生了,就是安排完所有的學生了已經 13 res=Math.min(res,num); 14 return; 15 } 16 for(int i=1;i<=num;i++){ //首先看看之前的房間里面能不能放進去 17 int sz=cnt[i]; 18 int jishu=0; //得到的是和這個人不認識的人數 19 for(int j=1;j<=sz;j++){ 20 if(gra[id][cun[i][j]]==0){ 21 jishu++; 22 } 23 } 24 if(jishu==sz){ //如果這里面的學生都和現在遍歷的都不認輸 25 cun[i][++cnt[i]]=id; //將這個學生存到這個考場中 26 solve(id+1,num); 27 cnt[i]--; 28 } 29 } 30 //重新開一個房間 31 cun[num+1][++cnt[num+1]]=id; //沒有的話就把它放到下一個教室里 32 solve(id+1,num+1); 33 --cnt[num+1]; 34 } 35 public static void main(String[] args) { 36 Scanner in = new Scanner(System.in); 37 n = in.nextInt(); 38 m = in.nextInt(); 39 gra=new int[110][110]; //是否存在關系,存在關系就是1,不存在關系就是0 40 cun=new int[110][110]; //第一維度表示的是考場,二位度里面放的是這個考場里面的學生 41 //cun[1][1] = 2,cun[1][2] = 0;表示考場1里面第一個存在的人是2,然后后面一位是0,也就是不存在人了,那么這時的cun[1] = 1;表示的是考場里面人的數量 42 cnt=new int[110]; //是cun數組存的是學生的數量 43 while(m-- >0){ 44 int a = in.nextInt(); 45 int b = in.nextInt(); 46 gra[a][b]=gra[b][a]=1; 47 } 48 solve(1,0); 49 System.out.println(res); 50 } 51 }