C语言实现纸牌游戏(小猫钓鱼)

 更新时间:2020年10月11日 17:08:13   作者:齐123  
这篇文章主要为大家详细介绍了C语言实现纸牌游戏,小猫钓鱼游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

C语言使用队列和栈实现纸牌游戏–小猫钓鱼,供大家参考,具体内容如下

C语言:

//纸牌游戏--小猫钓鱼--队列 栈--(所谓的拉火车) 
#include <stdio.h>

struct queue   //队列 
{
 int data[1000];
 int head;
 int tail;
}; 
struct stack   //栈 
{
 int data[10];
 int top;
};

int main(void)
{
 struct queue q1, q2; //小哼 q1 和小哈 q2 的队列 
 struct stack s;  //栈 
 int book[10];   //记录,判断是否第二次出现 
 int i, t;
 
 q1.head = 1, q1.tail = 1;  //初始化队列 
 q2.head = 1, q2.tail = 1; 
 
 s.top = 0;     //初始化栈 
 
 for(i = 1;i <= 9;i++)  //初始化出现次数为 0 
 book[i] = 0;
 
 for(i = 1; i <= 6; i++) {  //这里给定一个人 6 张牌 
 scanf("%d", &q1.data[q1.tail]);
 q1.tail++;
 }
 for(i = 1;i <= 6;i++) {
 scanf("%d", &q2.data[q2.tail]);
 q2.tail++;
 } 
 
 while(q1.head < q1.tail && q2.head < q2.tail ) {  //当队列不为空的时候执行循环 
 t = q1.data[q1.head];   //小哼(先)出牌 
 if(book[t] == 0){    //当桌上无此牌时 
 q1.head++;    //将此牌出队
 //s.top++;
 s.data[++s.top] = t;  //将打出的牌入栈 
 book[t] = 1;    //标记此牌桌上已有 
 }else{      //此牌桌上已有,小哼能赢
 q1.head++;    //将打出的此牌出队
 q1.data[q1.tail] = t; //将此牌入队尾 
 q1.tail++;
 
 while(s.data[s.top] != t) { //把桌子上赢的牌收回去, 此处没有收最后一根牌 t 
 book[s.data[s.top]] = 0;   //取消标记
 q1.data[q1.tail] = s.data[s.top]; //依次放在队尾 
 q1.tail++;
 s.top--;       //栈中少了一张牌,所以- 1 
 }
 //收回桌上的 t 牌 
 book[t] = 0;
 q1.data[q1.tail] = t;
 q1.tail++;
 s.top--; 
 }
 
 if(q1.head == q1.tail )   //如果小哼牌打完了,游戏结束 
 break; 
 
 //轮到小哈出牌了,和小哼一样判断 
 t = q2.data[q2.head];
 if(book[t] == 0) {
 q2.head++;
 s.top++;
 s.data[s.top] = t;
 book[t] = 1;
 } 
 else {
 q2.head++;
 q2.data[q2.tail] = t;
 q2.tail++;
 
 while(s.data[s.top] != t) {
 book[s.data[s.top]] = 0;
 q2.data[q2.tail] = s.data[s.top];
 q2.tail++;
 s.top--;
 } 
 
 book[t] = 0;
 q2.data[q2.tail] = t;
 q2.tail++;
 s.top--;
 } 
 } 
 
 if(q2.head == q2.tail ) {
 printf("小哼 win \n");
 printf("小哼当前手中的牌是 ");
 for(i = q1.head;i < q1.tail;i++)
 printf(" %d",q1.data[i]);
 
 if(s.top) {  //如果桌子上有牌的话 
 printf("\n桌子的牌是");
 for(i = 1;i <= s.top;i++)
 printf(" %d",s.data[i]);
 printf("\n"); 
 }
 else
 printf("\n桌子上已经没有牌了");
 } else {
 printf("小哈 win \n");
 printf("小哈当前手中的牌是 ");
 for(i = q2.head;i <= q2.tail-1;i++)
 printf(" %d", q2.data[i]);
 
 if(s.top) {  //如果桌子上有牌的话 
 printf("\n桌子的牌是");
 for(i = 1;i <= s.top;i++)
 printf(" %d",s.data[i]);
 printf("\n"); 
 } else
 printf("\n桌子上已经没有牌了");
 } 
 
 return 0;
} 
/*Code Running Results
1 2 3 4 5 6
3 2 1 5 2 6
小哈 win
小哈当前手中的牌是 5 6 2 3 1 3 2 5 2
桌子的牌是 4 6 1
*/

该程序使用队列来实现玩家的手中的牌(玩家的牌只能前面出牌,赢得牌依次放后面),用栈实现桌子上的牌(出牌放在末端,赢牌也是从末端拿走)。

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

相关文章

  • C++设计模式中的观察者模式一起来看看

    C++设计模式中的观察者模式一起来看看

    这篇文章主要为大家详细介绍了C++观察者模式,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • C++实现简单学生成绩管理系统

    C++实现简单学生成绩管理系统

    这篇文章主要为大家详细介绍了C++实现简单学生成绩管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • 如何利用C++实现mysql数据库的连接池详解

    如何利用C++实现mysql数据库的连接池详解

    为了提高MySQL数据库的访问的瓶颈,除了在服务器端增设缓存服务器缓存常用的数据之外(如redis),还可以增加数据库连接池,来提高MySQL Server的访问效率,这篇文章主要给大家介绍了关于如何利用C++实现mysql数据库的连接池的相关资料,需要的朋友可以参考下
    2021-07-07
  • C/C++练习题之合并k个已排序的链表

    C/C++练习题之合并k个已排序的链表

    这篇文章主要给大家介绍了关于C/C++练习题之合并k个已排序的链表的相关资料,文中通过图文以及实例代码介绍的非常详细,对大家学习或者使用C/C++具有一定的参考学习价值,需要的朋友可以参考下
    2023-06-06
  • OpenCV实现马赛克功能

    OpenCV实现马赛克功能

    这篇文章主要为大家详细介绍了OpenCV实现马赛克功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • Qt实现验证码相关功能的代码示例

    Qt实现验证码相关功能的代码示例

    验证码的原理基于人类视觉和计算机视觉的差异性,通过给用户显示一些难以被机器识别的图形或文字,让用户进行人机交互,确认自己的身份,这样可以有效保护网站安全,所以本给大家介绍了Qt实现验证码相关功能的代码示例,感兴趣的朋友可以参考下
    2024-01-01
  • c++ 移动构造相关总结

    c++ 移动构造相关总结

    这篇文章主要介绍了c++ 移动构造的相关资料,帮助大家更好的理解和学习使用c++,感兴趣的朋友可以了解下
    2021-02-02
  • C/C++高精度运算(大整数运算)详细讲解

    C/C++高精度运算(大整数运算)详细讲解

    高精度算法的本质是把大数拆成若干固定长度的块,然后对每一块进行相应的运算,下面这篇文章主要给大家介绍了关于C/C++高精度运算(大整数运算)的相关资料,需要的朋友可以参考下
    2022-11-11
  • 基于C++自动化编译工具的使用详解

    基于C++自动化编译工具的使用详解

    本篇文章是对C++中自动化编译工具的使用进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C语言实现猜数字大小的游戏

    C语言实现猜数字大小的游戏

    这篇文章主要为大家详细介绍了C语言实现猜数字大小的游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-01-01

最新评论