C语言实现洗牌发牌小程序

时间:2022-11-28 13:34:48

本文实例为大家分享了C语言实现洗牌发牌小程序的具体代码,供大家参考,具体内容如下

构建一副扑克牌,并实现洗牌发牌。

代码

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
 
#define NUM 10000 //洗牌混乱度
 
char color[7][7] = {"空白","红桃","黑桃","草花","方片","小王","大王"}; // 1:红桃 2:黑桃 3:草花 4:方片 5:小王 6:大王
char number[]={"0A234567890JQK"}; // 0:不存内容 1:A 2:2 3:3 4:4 5:5 6:6 7:7 8:8 9:9 10:10 11:J 12:Q 13:K
 
//构建扑克
struct card{
  unsigned int number;
  unsigned int color;
};
 
unsigned int NUM_card=53; //剩余未发的牌数(发牌时用的变量)
 
struct card card[54]; //创建保存一副牌的结构体
 
 
//构建一副牌(有序)
void creat_pair_card()
{
  int num=1;
  int col=1;
  int i=0;
  for(num=1;num<=15;num++)
  {
    //生成大小王
    if(num>=14)
    {
      card[i].number=num;
      card[i].color=col++;
      i++;
    }
    else
    {
      //生成普通牌
      for(col=1;col<=4;col++)
      {
        card[i].number=num;
        card[i].color=col;
        i++;
      }
    }
  }
}
 
//显示一副牌
void print_card()
{
  int i; 
  int num,col; //点数与花色对应数组下标
  for(i=0;i<54;i++)
  {
    col=card[i].color;
    num=card[i].number;
    if(col>=5)
    {
      printf("%s\t",color[col]);
    }
    else
    {
      if(num==10)
      {
        printf("%s:",color[col]);
        printf("10\t");
      }
      else
      {
        printf("%s:",color[col]);
        printf("%c\t",number[num]);
      }
    }
  }
  printf("\n");
}
 
 
//洗牌
void wash_card()
{
  int i;
  int ch1,ch2;
  srand((unsigned)time(NULL));
  for(i=0;i<NUM;i++) //循环次数越大越乱
  {
    
    
    ch1=rand()%100; //2147483647 取最后两位0-99
    ch2=rand()%100;
    
 
    if(ch1>53)
    {
      ch1=100-ch1; //随机数大于53则减小
    }
 
    if(ch2>53)
    {
      ch2=100-ch2;
    }
 
    if(ch1 == ch2)
    {
      continue;
    }
    //两个随机牌交换
    struct card tmp=card[ch1];
    card[ch1]=card[ch2];
    card[ch2]=tmp;
  }
}
 
//发牌
void send_card(struct card hand[],int num)
{
  if(NUM_card<num)
  {
    printf("数量不足\n");
    return;
  }
  int i;
  for(i=0;i<num;i++)
  {
    hand[i]=card[NUM_card-i];
  }
  NUM_card=NUM_card-num;
}
 
 
//显示手牌
void print_hand_card(struct card hand[],int num)
{
  int i;
  int point,col;
  for(i=0;i<num;i++)
  {
    col=hand[i].color;
    point=hand[i].number;
    if(col>=5)
    {
      printf("%s ",color[col]);
    }
    else
    {
      if(point==10)
      {
        printf("%s:",color[col]);
        printf("10 ");
      }
      else
      {
        printf("%s:",color[col]);
        printf("%c ",number[point]);
      }
    }
  }
  printf("\n");
}
 
 
int main(void)
{
 
  creat_pair_card(); //创建一副牌 有序
  wash_card();//洗牌
  print_card();//打印
 
  struct card hand1[17]; //创建两个结构体保存手牌17张
  struct card hand2[17];
  send_card(hand1,17); //发牌
  send_card(hand2,17);
  printf("手牌A: ");
  print_hand_card(hand1,17);
  printf("\n");
  printf("手牌B: ");
  print_hand_card(hand2,17);
  printf("\n");
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/lmory233/article/details/80238923