Full Flush C语言实现

本文介绍了一个用于判断麻将手牌是否胡牌的算法实现。该算法通过输入一个由14个字符组成的字符串来代表一副完整的麻将手牌,并通过一系列函数进行格式验证、排序及胡牌逻辑判断。文章详细解释了如何检查手牌的有效性、排序手牌以及最终确定手牌是否构成胡牌的状态。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include "stdafx.h"
#include "stdio.h"
#include "stdlib.h"
#include "string.h"

bool ok(char buf[])	{	//判断一个串是不是整数串
	if ( strlen(buf) != 14 ) {
		return false;
	}
	int i;
	for(i=0; buf[i]; i++) {
		if(buf[i] < '1'|| buf[i] > '9')
			return false;
	}
	return true;
}

void bubbleSort(char buf[]) {
	int length = strlen(buf);
	for (int i = 0; i <= length - 1; i++) {
		for (int j = length - 1; j > i; j--) {
			if (buf[j] < buf[j-1]) {
				int temp = buf[j];
				buf[j] = buf[j-1];
				buf[j-1] = temp;
			}
		}
	}
}

char* subString(char buf[], int pos, int len) {
	char* str = (char*)malloc(len*sizeof(char));
	int i;
	for (i = 0; i < len; i++) {
		str[i] = buf[i+pos];
	}
	return str;
}

bool check(char buf[], int len) {
	if (len == 0 ) {
		return true;
	}
	if (buf[0] == buf[1]) {
		char* str = subString(buf, 2, len-2);
		if ( check(str, len-2) ) {		// 检查一对
			return true;
		}
		if (buf[1] == buf[2]) {			// 检查“碰”
			char* str1 = subString(buf, 3, len-3);
			if ( check(str1, len-3) ) {
				return true;
			}
			if (buf[2] == buf[3]) {		// 检查“杠”
				char* str2 = subString(buf, 4, len-4);
				if ( check(str2, len-4) ) {
					return true;
				}
				else
					return false;
			}
		}
		return false;
	}
	else if (buf[1] == buf[0] + 1 && buf[2] == buf[1] + 1) {	// 检查“吃”
		char* str3 = subString(buf, 3, len-3);
		if ( check(str3, len-3) )
			return true;
		else
			return false;
	}
	return false;
}

void main(int argc, char* argv[]) {
	char str[14];
    printf("please input a complete Mahjong Hand (0 to end):");
    scanf("%s",str);
	while ( strlen(str) != 1 || atoi(str) != 0 ) {
		if ( !ok(str) ) {
			printf("Wrong format! \n");
		}
		else {
			bubbleSort(str);
			printf("The sorted sequence: %s\n", str);
			if ( check(str, 14) ) {
				printf("You Win! \n");
			}
			else{
				printf("Not Win! \n");
			}
		}
		printf("please input a complete Mahjong Hand (0 to end):");
		scanf("%s",str);
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值