牌型种数
牌型种数
小明被劫持到X赌城,被迫与其他3人玩牌。
一副扑克牌(去掉大小王牌,共52张),均匀发给4个人,每个人13张。
这时,小明脑子里突然冒出一个问题:
如果不考虑花色,只考虑点数,也不考虑自己得到的牌的先后顺序,自己手里能拿到的初始牌型组合一共有多少种呢?
请填写该整数,不要填写任何多余的内容或说明文字。
1 #include<stdio.h> 2 #include<iostream> 3 #include<string.h> 4 using namespace std; 5 long long int ans=0; 6 void dfs(int cur,int sum)//cur代表牌的种类,sum代表一个人得到牌的总数 7 { 8 int i; 9 if(sum>13)//还没把所有牌的种类遍历完就已经超过13张 10 { 11 return ; 12 } 13 if(cur==13) 14 { 15 if(sum==13) 16 ans++; 17 return ; 18 } 19 20 for(i=0;i<=4;i++)//i代表每种牌取得张数 21 dfs(cur+1,sum+i); 22 } 23 int main() 24 { 25 dfs(0,0); 26 cout<<ans<<endl; 27 return 0; 28 }
1 #include <iostream> 2 using namespace std; 3 int main() 4 { 5 int sum=0; 6 for(int a=0; a<=4; a++) 7 for(int b=0; b<=4; b++) 8 for(int c=0; c<=4; c++) 9 for(int d=0; d<=4; d++) 10 for(int e=0; e<=4; e++) 11 for(int f=0; f<=4; f++) 12 for(int g=0; g<=4; g++) 13 for(int h=0; h<=4; h++) 14 for(int i=0; i<=4; i++) 15 for(int j=0; j<=4; j++) 16 for(int k=0; k<=4; k++) 17 for(int l=0; l<=4; l++) 18 for(int m=0; m<=4; m++) 19 { 20 if(a+b+c+d+e+f+g+h+i+j+k+l+m==13) 21 sum++; 22 } 23 cout<<sum<<endl; 24 return 0; 25 }
浙公网安备 33010602011771号