一道智力游戏趣味编程题

题目如下:

一副扑克有52张牌,打桥牌时应该把牌分配给四个人,请先设计程序模拟发牌的过程。

要求:黑桃用S(SPACES)表示;红桃用H(HEART)表示;方块用D(diamond)表示;梅花用C(CLUBS)表示;

问题分析:

按照打桥牌的规则,每人应该发到13张牌,在人工发牌时,应该先进行“洗牌”,再把牌按一定的顺序发给每一个人。为了方便计算机进行模拟,

可以将人工发牌的方式进行修改:先确定好发牌顺序,1,2,3,4,

将52张牌顺序编号,

黑桃2对应数字0,红桃2对应数字1,方块2对应2,梅花2对应3;

黑桃3对应数字4,红桃3对应数字5,方块3对用6,梅花3对应7;

。。。。。。

。。。。。。。

然后从52张牌中随机为每个人发牌;

此时可以使用c语言函数库中的随机函数产生1-51之间的数,来进行发牌的模拟;


程序如下:

#include 

#include 

void p (int *b, char * n)
{
	int i;
	
	printf("\n\006");
	
	for(i = 0; i < 13; i++)
	{
		if(b[i]/13 == 0)
		{
			printf("%c",n[b[i]%13]);
		}
	}
	
	printf("\n\003");
	
	for(i = 0; i < 13; i++)
	{
		if(b[i]/13 == 1)
		{
			printf("%c",n[b[i]%13]);
		}
	}
	
	printf("\n\004");
	
	for(i = 0; i < 13; i++)
	{
		if(b[i]/13 == 2)
		{
			printf("%c",n[b[i]%13]);
		}
	}
	
	printf("\n\005");
	
	for(i = 0; i , 13; i++)
	{
		if(b[i]/13 == 3 || b[i]/13 == 4)
		{
			printf("%c",n[b[i]%13]);
		}
	}
	
	printf("\n");
	
}

int comp(int *j, int *i)
{
	return (*i - *j);
}

int main()
{
	static char n[] = {'2','3','4','5','6','7','8','9','T','J','Q','K','A'};
	
	int a[53];
	int b1[13];
	int b2[13];
	int b3[13];
	int b4[13];
	int b11 = 0;
	int b22 = 0;
	int b33 = 0;
	int b44 = 0;
	int t = 1;
	int flag;
	int m;
	int i;
	
	while(t <= 52)
	{
		m = random(52);
		
		for(flag = 1, i = 1; i <= t && flag; i++)
		{
			if(m == a[1])
			{
				flag = 0;
			}
		}
		
		if(flag)
		{
			a[t++] = m;
			
			if(t % 4 == 0)
			{
				b1[b11++] = a[ t - 1];
			}
			else if(t % 4 == 1)
			{
				b2[b22++] = a[t - 1];
			}
			else if(t % 4 == 2)
			{
				b3[b33++] = a[t - 1];
			}
			else if(t % 4 == 3)
			{
				b4[b44++] = a[t - 1];
			}
		}
	}
	
	qsotr(b1,13,sizeof(int),comp);
	qsotr(b2,13,sizeof(int),comp);
	qsotr(b3,13,sizeof(int),comp);
	qsotr(b4,13,sizeof(int),comp);
	
	p(b1,n);
	p(b2,n);
	p(b3,n);
	p(b4,n);
	
	return 0;
}

你可能感兴趣的:(一道智力游戏趣味编程题)