东华oj-基础题第60题-发牌

在这里插入图片描述

60 发牌

作者: 朱星垠时间限制: 2S章节: 二维数组

问题描述 :

编制一个模拟发牌的程序。有编号为1,2,3,4四个人,将一付去掉大小怪的扑克按照如下顺序排列梅花c0-c12,方块d0-d12,红桃h0–h12,黑桃s0-s12,然后按照1,2,3,4四个人的顺序发牌,问最后每个人手上的牌有哪些。

输入说明 :

你的程序需要从标准输入设备(通常为键盘)中读入多组测试数据。每组输入数据由一行组成。每组数据包含一个在1到4之间的整数,代表四个人中的一个,在行首和行尾没有多余的空格。

输出说明 :

对每组测试数据,你的程序需要向标准输出设备(通常为启动该程序的终端)依次输出一组对应的答案。对于每组输入,输出那个人手上的牌。每组一行。每行包括13张牌,每张牌由牌的花色和牌的大小组成。牌的花色和牌的大小之间有一个空格,前后两张牌之间也有一个空格。其余数据前后没有多余的空格,两组数据之间也没有多余的空行。

输入范例 :
1
2

输出范例 :
c 0 c 4 c 8 c 12 d 3 d 7 d 11 h 2 h 6 h 10 s 1 s 5 s 9
c 1 c 5 c 9 d 0 d 4 d 8 d 12 h 3 h 7 h 11 s 2 s 6 s 10

代码:

/*
	T60 发牌 
	算法概述:由于发给每个人的牌的规律是一样的:都是隔4次发一张。
	所以可以用num表示牌的数字,直接输出发的牌的花色和编号,输出一次
	将num累加4,若num超过12,那么说明需要发下一种花色的牌了,这个时
	候num%13,花色更新一下就可以了,总共输出十三次 
*/

#include<stdio.h>

int main()  {
	int i = 0;// 统计已发的牌张数
	int num = 0;// 当前牌的数字 
	int count = 0;// 统计换花色的次数 
	int perNum = 0;// 人员编号
	char patterns[5] = "cdhsc";
	char ch = patterns[count];// 当前牌的花色 
	
	while (scanf("%d", &perNum) != EOF) {
		 // 重置数据 
		 i = 0;
		 num = perNum - 1;
		 count = 0;
		 ch = patterns[count]; 
 
		 printf("c %d", num); 
		 i++;
		 while (i < 13) {
		 	 num += 4;
		     if (num > 12) {
		     	 num %= 13;
		     	 ch = patterns[++count];// 换花色 
		     	 printf(" %c %d", ch, num);
		     }
		     else {
		     	 printf(" %c %d", ch, num);
		     }
		     i++;
		 }
		 printf("\n");
	} 
	
	return 0;
} 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章