本文主要是介绍第六届蓝桥杯省赛C++B组 牌型种数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
牌型种数
小明被劫持到X赌城,被迫与其他3人玩牌。
一副扑克牌(去掉大小王牌,共52张),均匀发给4个人,每个人13张。
这时,小明脑子里突然冒出一个问题:
如果不考虑花色,只考虑点数,也不考虑自己得到的牌的先后顺序,自己手里能拿到的初始牌型组合一共有多少种呢?
请填写该整数,不要填写任何多余的内容或说明文字。
答案:3598180
思路:其实13重循环也跑的出来hhhhh 这里我用的dfs。
代码:
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<iostream>
#include<algorithm>
#include<string>
#include<vector>
#include<queue>
#include<map>
#include<set>
using namespace std;int ans=0;
void dfs(int card,int kind)
{if(card>13||kind>13)return;if(card==13&&kind<=13){ans++;return;}for(int i=0;i<=4;i++)dfs(card+i,kind+1);
}
int main()
{dfs(0,0);cout<<ans<<endl;return 0;
}
这篇关于第六届蓝桥杯省赛C++B组 牌型种数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!