藍橋杯 分考場 JAVA


 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 }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM