推断5张扑克牌的组成

一副牌中发五张扑克牌给你,让你推断数字的组成:
有下面几种情况:
1:四条:即四张一样数值的牌(牌均不论花色)
2:三条带一对
3:三条带两张不同样数值的牌
4:两对
5:顺子(包含10,J,Q,K,A)
6:什么都不是

7:仅仅有一对 

分析:

应该不包括大小王,另外J、Q、K、A分别相当于11、12、13、14,尽管从2到A一共是13张牌。可是为了方便相应,使用了一个包括15个元素的数组来记录每个点数出现的次数(舍弃0号元素和1号元素)。

为了记录发给你的5张牌。直接用整型肯定不行,不能接受J、Q、K、A的输入,刚開始的时候准备使用一个字符数组接受输入,然后再转换为整型。可是字符输入是不能接受10这种输入的,最后仅仅能使用字符串数组接受输入。

C代码例如以下:

#include
#include
#include

#define LEN 5
#define TOTAL_LEN 15 

char str_poker[LEN][3];
int int_poker[LEN] = {0};
int total_poker[TOTAL_LEN] = {0};

void check(int len, int poker[]);
void ch_to_int(int len, char str_array[][3], int int_array[]);
void int_sort(int len, int a[]);

int main()
{
	int i;
	printf("please input your cards:");
	for(i=0; i a[j+1])
			{
				temp = a[j];
				a[j] = a[j+1];
				a[j+1] = temp;
			}
}

void check(int len, int poker[])
{
	int i;
	int res = 1;
	for(i=0; i= 2)
			res *= total_poker[i];
	}
	if(res > 1)
	{
		switch(res)
		{
		case 2:
			printf("一对加三张不同\n");
			break;
		case 3:
			printf("三条加两张不同\n");
			break;
		case 4:
			printf("两队加一张\n");
			break;
		case 6:
			printf("三条加一对\n");
			break;
		}
	}
	else
	{
		int_sort(LEN, poker);
		for(i=0; i


几组測试用比例如以下:



你可能感兴趣的:(推断5张扑克牌的组成)