鉴于昨天种种,不添加敏感字眼咯
非baidu google 抄来的
自己花了两个下午写的,鉴于昨天别热的讨论,做了几处优化
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
extern int rand1(void);
extern void srand1(int);
extern void yanshi(int i);
extern void End();
extern int shaizi(int sides);
extern void xipai(int *p); //洗牌程序
extern void sjsz(int *p,int n); //产生一组n的随即数组,并存储在p[n]数组中
extern void paixu(int *p,int n);
extern char pipei(int num);
extern void shuchu(int *p); //用于输出每个玩家手里的牌
#define REN 3 //打牌人数,此处斗地主不要改
#define JIFUPAI 1 //几副扑克 此处斗地主不要改
#define DANWEI 54 //每副牌的张数
#define PAI (DANWEI*JIFUPAI) //扑克总张数
#define JHCS 100000 //洗牌程序申请的交换次数 extern int meigewanjia(int *p,int n); //显示当前玩家手里的牌,n为牌张数
extern int chupai(int *p,int x,int n); //将玩家出完的牌标记为0,x为玩家出的牌,n为每个玩家目前牌的张数,然后返回玩家牌的数目
extern int duiying(char ch); //将玩家输入的字符式牌点换为对应的int数字
int main(void)
{
int i,x,y,z,flag;
int * p=(int *)calloc(PAI,sizeof(int)); //请求54张牌的存储空间;
int *pa,*pb,*pc;
char ch;
for(i=0;i<PAI;i++)
p[i]=i+1; //初始化牌数组内的牌点数,即对应数组下标
pa=p;pb=p+PAI/REN;pc=p+PAI/REN*2;
xipai(p);
flag=PAI/REN;
for(i=0;i<100;i++)
{ printf("玩家A的牌:\n");
x=meigewanjia(pa,flag);
printf("玩家B的牌:\n");
y=meigewanjia(pb,flag);
printf("玩家C的牌:\n");
z=meigewanjia(pc,flag);
if(x==0||y==0||z==0) break;
puts("玩家A出牌:");
ch=getchar();
chupai(pa,duiying(ch),flag);
fflush(stdin);
puts("玩家B出牌:");
ch=getchar();
chupai(pb,duiying(ch),flag);
fflush(stdin);
puts("玩家C出牌:");
ch=getchar();
chupai(pc,duiying(ch),flag);
fflush(stdin);
}
free(p) ;
End();
}
void xipai(int *p) //洗牌程序
{
int * sui,temp,i;
sui=(int *)calloc(JHCS,sizeof(int)); //申请存放随机数的空间
sjsz(sui,JHCS); //产生JHCS个随机数,也就是交换次数,并放在数组sui中。 for(i=0;i<JHCS-2;i=i+2) //根据随机数产生的数组下标交换JHCS次;
{
temp=p[(sui[i])];
p[(sui[i])]=p[(sui[i+1])];
p[(sui[i+1])]=temp;
}
free(sui);
}
void sjsz(int *p,int n) //产生一组n的随机数组,并存储在p【n】数组中,用于洗牌用
{
int i;
srand((unsigned int)time(0)); //以系统时间作为种子
for(i=0;i<n;i++)
p[i]=rand()%PAI;
}
void paixu(int *p,int n) //给每个玩家的牌从小到大排序
{
int i,j,temp;
for(i=0;i<n-1;i++)
{
for(j=i+1;j<n;j++)
{
if(p[i]>p[j])
{
temp=p[i];p[i]=p[j];p[j]=temp;
}
}
}
}
char pipei(int num) //用于和上述数组内1——PAI的数字进行牌张匹配
{
char paidian;
if(num<=52*JIFUPAI)
paidian="34567890JQKA2"[(num-1)/(4*JIFUPAI)]; if(num>52*JIFUPAI&&num<=52*JIFUPAI+JIFUPAI) paidian='x';
非baidu google 抄来的
自己花了两个下午写的,鉴于昨天别热的讨论,做了几处优化
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
extern int rand1(void);
extern void srand1(int);
extern void yanshi(int i);
extern void End();
extern int shaizi(int sides);
extern void xipai(int *p); //洗牌程序
extern void sjsz(int *p,int n); //产生一组n的随即数组,并存储在p[n]数组中
extern void paixu(int *p,int n);
extern char pipei(int num);
extern void shuchu(int *p); //用于输出每个玩家手里的牌
#define REN 3 //打牌人数,此处斗地主不要改
#define JIFUPAI 1 //几副扑克 此处斗地主不要改
#define DANWEI 54 //每副牌的张数
#define PAI (DANWEI*JIFUPAI) //扑克总张数
#define JHCS 100000 //洗牌程序申请的交换次数 extern int meigewanjia(int *p,int n); //显示当前玩家手里的牌,n为牌张数
extern int chupai(int *p,int x,int n); //将玩家出完的牌标记为0,x为玩家出的牌,n为每个玩家目前牌的张数,然后返回玩家牌的数目
extern int duiying(char ch); //将玩家输入的字符式牌点换为对应的int数字
int main(void)
{
int i,x,y,z,flag;
int * p=(int *)calloc(PAI,sizeof(int)); //请求54张牌的存储空间;
int *pa,*pb,*pc;
char ch;
for(i=0;i<PAI;i++)
p[i]=i+1; //初始化牌数组内的牌点数,即对应数组下标
pa=p;pb=p+PAI/REN;pc=p+PAI/REN*2;
xipai(p);
flag=PAI/REN;
for(i=0;i<100;i++)
{ printf("玩家A的牌:\n");
x=meigewanjia(pa,flag);
printf("玩家B的牌:\n");
y=meigewanjia(pb,flag);
printf("玩家C的牌:\n");
z=meigewanjia(pc,flag);
if(x==0||y==0||z==0) break;
puts("玩家A出牌:");
ch=getchar();
chupai(pa,duiying(ch),flag);
fflush(stdin);
puts("玩家B出牌:");
ch=getchar();
chupai(pb,duiying(ch),flag);
fflush(stdin);
puts("玩家C出牌:");
ch=getchar();
chupai(pc,duiying(ch),flag);
fflush(stdin);
}
free(p) ;
End();
}
void xipai(int *p) //洗牌程序
{
int * sui,temp,i;
sui=(int *)calloc(JHCS,sizeof(int)); //申请存放随机数的空间
sjsz(sui,JHCS); //产生JHCS个随机数,也就是交换次数,并放在数组sui中。 for(i=0;i<JHCS-2;i=i+2) //根据随机数产生的数组下标交换JHCS次;
{
temp=p[(sui[i])];
p[(sui[i])]=p[(sui[i+1])];
p[(sui[i+1])]=temp;
}
free(sui);
}
void sjsz(int *p,int n) //产生一组n的随机数组,并存储在p【n】数组中,用于洗牌用
{
int i;
srand((unsigned int)time(0)); //以系统时间作为种子
for(i=0;i<n;i++)
p[i]=rand()%PAI;
}
void paixu(int *p,int n) //给每个玩家的牌从小到大排序
{
int i,j,temp;
for(i=0;i<n-1;i++)
{
for(j=i+1;j<n;j++)
{
if(p[i]>p[j])
{
temp=p[i];p[i]=p[j];p[j]=temp;
}
}
}
}
char pipei(int num) //用于和上述数组内1——PAI的数字进行牌张匹配
{
char paidian;
if(num<=52*JIFUPAI)
paidian="34567890JQKA2"[(num-1)/(4*JIFUPAI)]; if(num>52*JIFUPAI&&num<=52*JIFUPAI+JIFUPAI) paidian='x';