玩扑克c语言
㈠ c语言程序设计扑克牌游戏
定义一个结构类型表示一张牌,结构包含3个成员,第一个成员char:取值2,3~K,A表示牌名字,第二个成员int:取值2~14表示牌真实大小。第三个成员:结构链表指针。
写一个初始化函数,定义52大小的结构数组,成员值初值分别和牌对应,遍历数组并将每个元素的链表指针依次指向下一个元素地址。这样得到一个初始链表。(相当于一盒新牌)
所有涉及随机数都用rand函数,洗牌分四份就是循环取随机数m=1~n,n是随循环自减,初值52,直到n变成0。每随一次循环就从初始链表中遍历取出对应第m个节点,并从初始链表中将这个节点断开(既前一个节点指针直接指向后一个节点指针)。每取13张就组成一个新的链表。这样获得4个新链表分别表示4个玩家。
最后出牌就是分别遍历自己的链表,利用循环取牌比较结构数值大小。(取出的牌要从链表断开和上面一样,你把取出节点写成独立函数就能反复使用)。
㈡ 如何用c语言编德州扑克
#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
#include <time.h>
#include <string.h>
const char ranks[]= {'A','2','3','4','5','6','7','8','9','T','J','Q','K'};
const char suits[]= {'C','D','H','S'};
int num[7]= {0,1,2,3,4,5,6};
int in_hand[4][13]= {0}; /*防止发到重覆的牌*/
int repeat[13]= {0}; /*存数字重复的数量*/
int cnt=0,cnt2=1;
int max=0; /*存最佳牌型的值*/
typedef struct Sort_ /*分开存每张牌的花色及数字*/
{
char suit;
int rank;
} Sort;
Sort rec_cards[52]; /*出现过的牌*/
Sort p_cards[2]; /*玩家手牌*/
Sort r_cards[2]; /*电脑手牌*/
Sort s_cards[5]; /*公牌*/
Sort c_cards[7]; /*手牌+公牌*/
Sort m_cards[5]; /*c_cards 7取5 出来的阵列*/
Sort n_cards[5]; /*存最佳牌型*/
Sort t_cards[5]; /*暂存牌型*/
int compare(const Sort *a,const Sort *b) /*qsort比较函式*/
{
...
}
void combine_sort(Sort a[],Sort b[],int len_a,int len_b) /*合并手牌与公牌*/
{
int i;
for(i=0; i<len_a; i++)
c_cards[i]=a[i];
for(i=0; i<len_b; i++)
c_cards[i+len_a]=b[i];
qsort(c_cards,len_a+len_b,sizeof(Sort),compare);
}
bool straight(Sort data[]) /*判断顺子*/
{
int i,j,flag=0;
for(i=0; i<4; i++)
{
if(data[i].rank+1==data[i+1].rank)
{
flag++;
if(flag==3 && data[flag+1].rank==0 || flag==4)
return true;
}
else
return false;
}
}
int find_type(Sort data[]) /*判断牌型*/
{
int i,j,flag=0;
int repeat[13]= {0};
for(i=0; i<5; i++) /*纪录每个数字出现了几次*/
repeat[data[i].rank]++;
for(i=0; i<5; i++) /*同花顺*/
{
if (data[0].suit==data[i].suit)
{
if (i==4)
if (straight(data)==true)
return 9;
}
else break;
}
for(i=0; i<13; i++) /*四条*/
{
if(repeat[i]==4)
return 8;
}
for(i=0; i<13; i++) /*葫芦*/
{
if (repeat[i]==3)
for(j=0; j<13; j++)
{
if(repeat[j]==2)
return 7;
}
}
for(i=0; i<5; i++) /*同花*/
{
if (data[0].suit==data[i].suit)
{
if (i==4)
return 6;
}
else
break;
}
if(straight(data)==true) /*顺子*/
return 5;
for(i=0; i<13; i++) /*三条*/
{
if (repeat[i]==3)
for(j=0; j<5; j++)
{
if(repeat[j]==1)
return 4;
}
}
flag=0;
for(i=0; i<13; i++) /*两对*/
if (repeat[i]==2)
{
flag++;
if(flag==2)
return 3;
}
flag=0;
for(i=0; i<13; i++) /*一对*/
if (repeat[i]==2)
{
flag++;
if(flag==1)
return 2;
}
return 1; /*高牌*/
}
int combination(int data[],int after, int got) /* 找出手牌+公牌取5张的所有组合 */
{
int i;
if (5==got)
{
for (i=0; i<5; i++)
m_cards[i]=c_cards[data[i]];
int tmp=find_type(m_cards); /*每种组合丢入find_type找出是哪种牌型*/
if (tmp==max)
{
if (m_cards[4].rank>t_cards[4].rank)
{
if(m_cards[4].suit>t_cards[4].suit)
for (i=0; i<5; i++)
n_cards[i]=m_cards[i];
for (i=0; i<5; i++)
n_cards[i]=m_cards[i];
}
else
for (i=0; i<5; i++)
n_cards[i]=t_cards[i];
}
if (tmp>max)
{
max=tmp;
for (i = 0; i < 5; i++)
n_cards[i]=m_cards[i];
}
return;
}
for (i=after; i<7; i++)
{
int tmp=data[got];
data[got]=data[i];
data[i]=tmp;
combination(data,i + 1,got+1);
tmp=data[got];
data[got]=data[i];
data[i]=tmp;
}
}
int reset() /*重置max*/
{
max=0;
combination(num,0,0);
return max;
}
void num_to_type(int n) /*印出牌型名称*/
{
...
}
void save_cards(Sort a[],int len) /*把发的牌分别存起来*/
{
int i;
if (len==2 && cnt2%3==1)
for(i=0; i<2; i++)
p_cards[i]=a[i];
if (len==2 && cnt2%3==2)
for(i=0; i<2; i++)
r_cards[i]=a[i];
if (len==5)
for(i=0; i<5; i++)
s_cards[i]=a[i];
cnt2++;
}
void deal_cards(int n) /*发牌*/
{
int i,rank,suit;
Sort data[n];
for(i=0; i<n;)
{
suit=rand() % 4;
rank=rand() % 13;
if(in_hand[suit][rank]==0)
{
in_hand[suit][rank]=1;
printf("%c%c ",ranks[rank],suits[suit]);
data[i].suit=suits[suit];
data[i].rank=rank;
rec_cards[cnt].suit=suits[suit];
rec_cards[cnt].rank=rank;
i++;
cnt++;
}
}
save_cards(data,n);
qsort(rec_cards,cnt,sizeof(Sort),compare);
printf("\n\n");
}
void welcome() /*欢迎接口*/
{
...
}
int main()
{
srand((unsigned)time(NULL));
int i,round=0,p_tmp,r_tmp,p_win=0,r_win=0;
printf("是否开始游戏?(Y/N):");
welcome();
while(round++<5)
{
printf("\n");
printf("你的牌:\n");
deal_cards(2);
printf("电脑的牌:\n");
deal_cards(2);
printf("公牌:\n");
deal_cards(5);
printf("按任意键显示胜负\n\n");
getch();
combine_sort(p_cards,s_cards,2,5);
printf("你的牌与公牌:");
for(i=0; i<7; i++)
printf("%c%c ",ranks[c_cards[i].rank],c_cards[i].suit);
printf("\n");
p_tmp=reset();
printf("最佳组合:");
for(i=0; i<5; i++)
printf("%c%c ",ranks[n_cards[i].rank],n_cards[i].suit);
num_to_type(p_tmp);
combine_sort(r_cards,s_cards,2,5);
printf("\n\n电脑的牌与公牌:");
for(i=0; i<7; i++)
printf("%c%c ",ranks[c_cards[i].rank],c_cards[i].suit);
printf("\n");
r_tmp=reset();
printf("最佳组合:");
for(i=0; i<5; i++)
printf("%c%c ",ranks[n_cards[i].rank],n_cards[i].suit);
num_to_type(r_tmp);
if (p_tmp>r_tmp)
{
printf("\n你赢了!\n");
p_win++;
}
else if(p_tmp<r_tmp)
{
printf("\n你输了!\n");
r_win++;
}
else
printf("\n平手!\n");
printf("\n目前比数(你:电脑) %d:%d\n",p_win,r_win);
printf("\n已出现的纸牌:");
for(i=0; i<cnt; i++)
printf("%c%c ",ranks[rec_cards[i].rank],rec_cards[i].suit);
printf("张数:%d\n",cnt);
printf("\n按任意键进行下一局\n");
getch();
}
printf("\n游戏结束!\n\n最终比数(你:电脑) %d:%d",p_win,r_win);
}
㈢ C语言 编写扑克出牌规则函数,判断出牌是否符合规则
#include<stdio.h>
#include<string.h>
intisPokerVaild(char*str){
if(strlen(str)==1){
if((str[0]>='2'&&str[0]<='9')||str[0]=='0'||str[0]=='A'||str[0]=='J'||str[0]=='Q'||str[0]=='K')return1;
elsereturn0;
}
elseif(strlen(str)==2){
if(str[0]==str[1])return2;
elsereturn0;
}
elseif(strlen(str)==3){
if(str[0]==str[1]&&str[1]==str[2])return3;
elsereturn0;
}
elseif(strlen(str)==4){
if(str[0]==str[1]&&str[1]==str[2]&&str[2]==str[3])return4;
elsereturn0;
}
elseif(strlen(str)==5){
ints[5],n=0;
boolflag=true;
while(n<5){
switch(str[n]){
case'2':s[n]=1;break;
case'3':s[n]=3;break;
case'4':s[n]=4;break;
case'5':s[n]=5;break;
case'6':s[n]=6;break;
case'7':s[n]=7;break;
case'8':s[n]=8;break;
case'9':s[n]=9;break;
case'0':s[n]=10;break;
case'J':s[n]=11;break;
case'Q':s[n]=12;break;
case'K':s[n]=13;break;
case'A':s[n]=14;break;
}
n++;
}
for(n=0;n<4;){
if(s[n+1]!=s[n]+1){
flag=false;
break;
}
else{
flag=true;
n++;
}
}
if(flag)return5;
elsereturn0;
}
}
intmain(){
intiRet=isPokerVaild("3");//iRet=1
printf("%d ",iRet);
iRet=isPokerVaild("n");//iRet=0
printf("%d ",iRet);
iRet=isPokerVaild("66");//iRet=2
printf("%d ",iRet);
iRet=isPokerVaild("36");//iRet=0
printf("%d ",iRet);
iRet=isPokerVaild("555");//iRet=3
printf("%d ",iRet);
iRet=isPokerVaild("366");//iRet=0
printf("%d ",iRet);
iRet=isPokerVaild("8888");//iRet=4
printf("%d ",iRet);
iRet=isPokerVaild("4666");//iRet=0
printf("%d ",iRet);
iRet=isPokerVaild("0JQKA");//iRet=5
printf("%d ",iRet);
iRet=isPokerVaild("56789");//iRet=5
printf("%d ",iRet);
iRet=isPokerVaild("45789");//iRet=0
printf("%d ",iRet);
}
㈣ c语言扑克牌
定义个字符数组,存放A-K牌面的字母 char ch[][3]={"A","2","3","4","5","6","7","8","9","10","J","Q","K"};
牌的大小从A-K分别为 0-12
在输出牌的牌面字符时,输出ch数据中牌面值下标的字符串。如某牌数值是9,输出时如下:
printf("%s", ch[9]);
“%d\%c”是格式输出字符串,表示要输出一个整数(%d)一个字符(%c) ,后面的两个参数分别是整数,字符,和格式化字符串相对应。是转义符,对于要输出特殊字符时,需要在前面加上,比如输出时,就写成\;再如 " ,应写成";输出换行写成 ,输出回车写成 等。在这个题目中,和后面的%构不成特殊字符转义,所以不输出,删掉它也是一样的。