清一色是麻将的种类之一,指有一种花色的序数牌组成的胡牌。
数字1-9,每个数字最多4张牌;
我们不考虑具体的花色,我们只看数字;
刻字:三张一样的牌:111.222.333
顺子:三张连续的牌123,46,789
对子:两张连续的牌;11,22,33,44
需要一个程序实现,判定给定牌,是否可以和牌;
胡牌要求:麻将 牌张数只能是2,5,8,11,14
给定牌可以组合成,除1个对子以外的其他都是刻字或者顺子
胡牌输出YES否则NO
#include<stdio.h>
#include<iostream>using namespace std;
bool Group3Same(char *p, int n)
{
char * q;
int sp = 0;
int i, j;
q = p;
if (n == 0)
{
return true;
}
for (i = 0; i < n - 2; i++)
{
if (*(q + i + 1) == *(q + i) && *(q + i + 2) == *(q + i + 1))
{
if (i == n - 3) //把这三个元素移除,把后面的元素往前移动三格
{
*(q + i) = '\0';
p = q;
return true;
}
else
{
for (j = i; j < n - 3; j++)
{
*(q + j) = *(q + j + 3);
}
*(q + j) = '\0';