在斗地主扑克牌游戏中,扑克牌由小到大的顺序为:3,4,5,6,7,8,9,10,J,Q,K,A,2,玩家可以出的扑克牌阵型有:单张、对子、顺子、飞机、炸弹等。
其中顺子的出牌规则为:由至少5张由小到大连续递增的扑克牌组成,且不能包含2。
例如{3,4,5,6,7}、{3,4,5,6,7,8,9,10,J,Q,K,A}都是有效的顺子;而{J,Q,K,A,2}、{2,3,4,5,6}、{3,4,5,6}、{3,4,5,6,8}等都不是顺子。
利用字符串(不用字符是因为10有两个字符)数组把3 4 5 6 7 8 9...按顺序存下来,因为题目要求优先最长就不会出现3 4 5 6 7,6 7 8 9 10这种的两个顺子,不会出现有公用部分的顺子,还要求了从小输出那么枚举从小到大的牌,有顺子就输出即可
#include <bits/stdc++.h>
using namespace std;
#define N 15
string c[13]={"3","4","5","6","7","8","9","10","J","Q","K","A"};//12
map<string,int>mp;