标签:nes cep bottom otto rmi mmm row int memory
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 2945 Accepted Submission(s): 1413
有n个人和m对朋友关系,他们中间有关系好的,也有关系不好的。要使他们每个人的好朋友和一般朋友数量相等(比如一个人有2个好朋友,那么他就应该也有2个一般朋友),有多少种方案。
输入的时候就可以保存每个人的朋友总数,如果有一个人的朋友总数是奇数,那么就不可能达到题目要求的条件,直接输出0;
不然的话,就另外用2个数组保存每个人的好朋友数量和一般朋友数量,都是朋友总数的一半。
接下来就是dfs,先找好朋友关系,如果两个人中有一个人的好朋友关系用完了,那就只能看这两个人的坏朋友关系,如果其中有一个人的坏朋友关系也用完了,那就return;像第一个案例就是没到p==m,就return了。不然就继续找下去;能到p==m就表示所有组都己经找完了,而且也肯定是一半好朋友,一半坏朋友,不然的话中间就return了,不会再往下找(看了好久才明白emmmm)
http://www.voidcn.com/article/p-eifhpyyl-bhn.html
1 #include<bits/stdc++.h> 2 using namespace std; 3 int n,m; 4 int num[10]; 5 int pa[10],pb[10]; 6 int sum; 7 struct node 8 { 9 int x; 10 int y; 11 }q[50]; 12 13 void DFS(int p) 14 { 15 //printf("p = %d\n",p); 16 if(p == m) 17 { 18 sum++; 19 return ; 20 } 21 int x = q[p].x; 22 int y = q[p].y; 23 if(pa[x] && pa[y])//x和y的好朋友次数都还有 24 { 25 pa[x]--; 26 pa[y]--; 27 // cout<<"好朋友"<<x<<" "<<y<<endl; 28 DFS(p+1); 29 pa[x]++; 30 pa[y]++; 31 } 32 if(pb[x] && pb[y])//x和y的坏朋友次数都还有 33 { 34 pb[x]--; 35 pb[y]--; 36 // cout<<"坏朋友"<<x<<" "<<y<<endl; 37 DFS(p+1); 38 pb[x]++; 39 pb[y]++; 40 } 41 } 42 43 int main() 44 { 45 int T; 46 scanf("%d",&T); 47 while(T--) 48 { 49 sum = 0; 50 memset(num,0,sizeof(num)); 51 memset(pa,0,sizeof(pa)); 52 memset(pb,0,sizeof(pb)); 53 scanf("%d%d",&n,&m); 54 int x,y; 55 for(int i=0;i<m;i++) 56 { 57 scanf("%d%d",&x,&y); 58 q[i].x = x; 59 q[i].y = y; 60 num[x]++;//x的朋友数量加1 61 num[y]++; 62 } 63 int flag = 0; 64 for(int i=1;i<=n;i++) 65 { 66 pa[i] = num[i]/2;//i的好朋友是i的朋友总数的一半 67 pb[i] = num[i]/2;//一般朋友 68 if(num[i]%2 == 1)//因为要每个人的朋友好和一般朋友相等,所以如果出现奇数肯定不行 69 { 70 flag = 1; 71 break; 72 } 73 } 74 // cout<<endl; 75 if(flag) 76 { 77 printf("0\n"); 78 continue; 79 } 80 DFS(0); 81 printf("%d\n",sum); 82 } 83 return 0; 84 }
标签:nes cep bottom otto rmi mmm row int memory
原文地址:https://www.cnblogs.com/fqfzs/p/9961198.html