东华大学 oj71——发牌

问题描述 :
编制一个模拟发牌的程序。有编号为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

#include <stdio.h>
#include <stdlib.h>

/* run this program using the console pauser or add your own getch, system("pause") or input loop */
typedef struct{
	char ch;
	int num;
}cards;


int main(int argc, char *argv[]) {
	int n,i,j,count,k=0;
	cards card[52];
	//初始化牌 
	for(i=0;i<4;i++){
		for(j=0;j<13;j++){
			switch(i){
			case 0:card[k].ch='c';break;
			case 1:card[k].ch='d';break;
			case 2:card[k].ch='h';break;
			case 3:card[k].ch='s';break;
		}
			card[k++].num=j;
		}
	}
	
//	for(i=0;i<52;i++){
//		printf("%c %d\n",card[i].ch,card[i].num);
//	}
	
	while(scanf("%d",&n)!=EOF){
		count=0;
		for(i=n-1;i<52;i=4*count+(n-1)){
			if(count==12){
				printf("%c %d\n",card[i].ch,card[i].num);
			}
			else{
				printf("%c %d ",card[i].ch,card[i].num);
			}
			++count;
		}
	}
	return 0;
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值