C语言程序设计第四版(何钦铭、颜晖)第十一章 指针进阶之随机发牌

【例11-6】随机发牌。一副纸牌有52张,4种花色,每种花色13张。用程序模拟随机发牌过程,将52张牌按轮转的方式发放给4人,并输出发牌结果。

复制代码
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
struct card{
	int suit;
	int face;
};
int deal(struct card *wdeck);
int main(){
	const char *suit[4]={"红心","方块","梅花","黑桃"};
	const char *face[13]={"A","K","Q","J","10","9","8","7","6","5","4","3","2"};
	struct card deck[52];
	int i; 
	deal(deck);
	for(i=0;i<52;i++){
		if(i%13==0){
			printf("\nplayer:%d\n",i/13+1);
		}
		printf("%s%s ",suit[deck[i].suit],face[deck[i].face]);
	}
	return 0;
} 
int deal(struct card *wdeck){	//用于生成打乱顺序的牌 ,相当于创建完整牌组+洗牌 
	static int temp[52]={0};	//规定:0代表未被发出,1代表已发出;意味着使生成的随机数不重复 
	srand(time(NULL));
	int i,t,m;
	for(i=0;i<52;i++){
		while(1){
			m=rand()%52;		//随机发出的牌号
			if(temp[m]==0)break;//如果之前没发过这张牌号,则跳出循环确定该号牌的花色和点数;否则重新生成牌号 
		}
		temp[m]=1;
		t=(i%4)*13+(i/4);		//轮流发牌,0~12为1号牌主,13~25为2号牌主,26~38为3号牌主,39~51为4号牌主 
		wdeck[t].suit=m/13;	    //借助牌号确定花色和点数 
		wdeck[t].face=m%13; 
	}
}

输出结果:

player:1

方块10 红心4 梅花2 黑桃J 梅花6 梅花7 红心J 方块7 黑桃8 黑桃9 黑桃10 方块Q 黑桃4

player:2

红心7 梅花5 黑桃6 黑桃Q 红心6 黑桃3 方块8 红心10 梅花Q 红心3 梅花10 红心2 方块2

player:3

黑桃K 梅花K 梅花9 黑桃5 红心8 梅花3 方块4 方块9 梅花J 梅花8 方块A 红心5 红心K

player:4

梅花A 方块5 方块6 红心9 方块K 红心Q 黑桃2 方块3 梅花4 黑桃7 红心A 方块J 黑桃A

相关推荐
笨蛋不要掉眼泪2 分钟前
Java并发编程 :深入剖析LinkedBlockingQueue
java·开发语言·网络·并发
不会C语言的男孩5 分钟前
C++ Primer Plus 第10章:对象和类
开发语言·c++
不会C语言的男孩10 分钟前
C++ Primer Plus 第11章:使用类
开发语言·c++
yujunl31 分钟前
NetCore常用的中间件说明
开发语言
玖玥拾1 小时前
C/C++ 基础笔记(二)
c语言·c++
Hanniel2 小时前
Python 元类(下):进阶与实战建议
开发语言·python
会编程的土豆2 小时前
Go interface 底层的 itab 到底是什么
开发语言·后端·golang
千纸鹤の脉搏2 小时前
多线程的初步了解---进程与线程
java·开发语言·学习·线程
秋田君2 小时前
Qt 5.12.8 下载与安装教程(附网盘资源)
开发语言·qt
故事和你912 小时前
洛谷-【动态规划2】线性状态动态规划4
开发语言·数据结构·c++·算法·动态规划·图论