一道智力游戏趣味编程题
2016-11-25 20:01
399 查看
题目如下:
一副扑克有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 <stdio.h>
#include <stdlib.h>
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;
}
一副扑克有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 <stdio.h>
#include <stdlib.h>
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;
}
相关文章推荐
- 一道没人搞得定的趣味Shell编程游戏题!,看看你会不会?
- 每天一道编程题(一)----24点游戏
- (有兴趣的朋友进来看看)一道智力编程题
- 360的一道编程题
- 一道智力题与信息熵
- 趣味数学:解24点游戏小技巧
- 一道趣味算术题
- 趣味编程题之Blocked Billboard
- 编程序,一般情况下是个智力游戏。
- 一道简单的趣味编程
- 亚马逊一道智力面试题
- 很有趣的一道编程题,子弹分发问题
- 智力题——24.数字额头游戏
- 一天一道编程题之打印日期
- 每天一道编程题------------------将一个句子中单词编程倒序
- 智力游戏(猜数字)
- 一道智力题的数学解
- 趣味程序设计_抢n游戏(总结规律)
- 上海华为的一道关于指针方面的编程题
- 一道比较年龄大小编程题