java实现小猫钓鱼游戏

题目要求:

两人比赛,A,B,每人最开始分得6张手牌,手牌大小为从1到9
A先出牌,B后出牌,若出牌在桌面上存在,在出牌人获得两张相同牌中间的所有牌(包括两张相同牌),放入出牌人手中。
最后谁手中无牌判为负

import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;
import java.util.Stack;

/**
 * 模拟实现两人玩小猫钓鱼游戏
 * 判断谁先出完谁获胜
 * @author zyk
 *
 */
public class PlayGame {

  public static void main(String[] args) {
    Stack<Integer> deskStack = new Stack<>();//桌子上的牌,用栈进行管理
    Queue<Integer> playerA = new LinkedList();//用队列管理每个选手的牌
    Queue<Integer> playerB = new LinkedList();
    int book[] = new int[10];
    Scanner scanner = new Scanner(System.in);
    //发牌,每人6张
    for (int i = 0; i < 6; i++) {
      playerA.add(scanner.nextInt());
    }
    for (int i = 0; i < 6; i++) {
      playerB.add(scanner.nextInt());
    }
    //当两个队列都不为空,表示游戏没有结束
    while (!playerA.isEmpty() && !playerB.isEmpty()) {
      int ta = playerA.peek();//A出一张牌
      //判断A出的牌能不能赢牌
      if (book[ta] == 0) {//桌子上没有这张牌
        //A不能赢牌
        playerA.remove();//打出的牌出队列
        deskStack.add(ta);//打出的牌入栈
        book[ta]=1;//标记打出的牌出现在桌子上
      }else {//A能赢牌
        playerA.remove();//打出的牌出队列
        playerA.add(ta);//打出的牌入队列
        while (deskStack.lastElement()!=ta) {
          book[deskStack.lastElement()] = 0;
          playerA.add(deskStack.lastElement());
          deskStack.pop();
        }
      }
      int tb = playerB.peek();//B出一张牌
      //判断B出的牌能不能赢牌
      if (book[tb] == 0) {//桌子上没有这张牌
        //B不能赢牌
        playerB.remove();//打出的牌出队列
        deskStack.add(tb);//打出的牌入栈
        book[tb]=1;//标记打出的牌出现在桌子上
      }else {//B能赢牌
        playerB.remove();//打出的牌出队列
        playerB.add(tb);//打出的牌入队列
        while (deskStack.lastElement()!=tb) {
          book[deskStack.lastElement()] = 0;
          playerB.add(deskStack.lastElement());
          deskStack.pop();
        }
      }
    }
    if (playerA.isEmpty()) {
      System.out.println("B赢了");
      System.out.print("B手中的牌为:");
      while (!playerB.isEmpty()) {
        System.out.print(playerB.peek()+" ");
        playerB.remove();
      }

    }else {
      System.out.println("A赢了");
      System.out.print("A手中的牌为:");
      while (!playerA.isEmpty()) {
        System.out.print(playerA.peek()+" ");
        playerA.remove();
      }
    }
    System.out.println("");
    System.out.print("桌子上的牌为:");
    while (!deskStack.isEmpty()) {
      System.out.print(deskStack.lastElement()+" ");
      deskStack.pop();
    }

  }

}

实例:

输入:
2 4 1 2 5 6
3 1 3 5 6 4

输出:
A赢了
A手中的牌为:5 6 2 3 1 4 6 5

参考: 《啊哈算法》第二章 栈,队列,链表

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

(0)

相关推荐

  • JAVA collection集合之扑克牌游戏实例

    Collection 层次结构中的根接口.Collection表示一组对象,这些对象也称为collection的元素.一些 collection 允许有重复的元素,而另一些则不允许.一些 collection 是有序的,而另一些则是无序的.JDK 不提供此接口的任何直接 实现:它提供更具体的子接口(如 Set 和 List)实现.此接口通常用来传递 collection,并在需要最大普遍性的地方操作这些 collection. 主要内容:这里使用collection集合,模拟香港电影中大佬们玩的

  • java实现纸牌游戏之小猫钓鱼算法

    星期天小哼和小哈约在一起玩桌游,他们正在玩一个非常古怪的扑克游戏--"小猫钓鱼".游戏的规则是这样的:将一副扑克牌平均分成两份,每人拿一份.小哼先拿出手中的第一张扑克牌放在桌上,然后小哈也拿出手中的第一张扑克牌,并放在小哼刚打出的扑克牌的上面,就像这样两人交替出牌.出牌时,如果某人打出的牌与桌上某张牌的牌面相同,即可将两张相同的牌及其中间所夹的牌全部取走,并依次放到自己手中牌的末尾.当任意一人手中的牌全部出完时,游戏结束,对手获胜. 假如游戏开始时,小哼手中有 6 张牌,顺序为 2 4

  • Java编写的24点纸牌游戏

    任意4个1-13数字,加减乘除计算24点. 实现原理: 1)排列组合4个数字 2)计算每次排列组合的可能性 Cal24.java import java.util.HashSet; import java.util.Set; public class Cal24 { private static final double precision = 0.00001; private static final int target = 24; public String[] execute(Strin

  • java实现小猫钓鱼游戏

    题目要求: 两人比赛,A,B,每人最开始分得6张手牌,手牌大小为从1到9 A先出牌,B后出牌,若出牌在桌面上存在,在出牌人获得两张相同牌中间的所有牌(包括两张相同牌),放入出牌人手中. 最后谁手中无牌判为负 import java.util.LinkedList; import java.util.Queue; import java.util.Scanner; import java.util.Stack; /** * 模拟实现两人玩小猫钓鱼游戏 * 判断谁先出完谁获胜 * @author z

  • Java太阳系小游戏分析和源码详解

    最近看了面向对象的一些知识,然后跟着老师的讲解做了一个太阳系各行星绕太阳转的小游戏,来练习巩固一下最近学的知识: 用到知识点:类的继承.方法的重载与重写.多态.封装等 分析: 1.需要加载图片.画图 2.建一个面板,主页面 3.行星类 效果图: 先看一下源码结构图: 现在逐步分析各个类的功能: 1)工具类-----util包中 --Constant类   封装了游戏中用到的常量 --GameUtil类  封装了游戏的图片加载功能 --MyFrame类  封装了游戏面板的构造,用于各面板的父类 -

  • java贪吃蛇游戏编写代码

    本文实例为大家分享了java贪吃蛇游戏展示的具体代码,供大家参考,具体内容如下 1.采用MVC(model.view.control)框架模式 2.包和类的关系树形图为: 3.源码: package com.huai; import Java.awt.Color; import java.awt.Graphics; import java.awt.Point; import java.util.HashSet; import java.util.LinkedList; import java.u

  • 基于Java代码实现游戏服务器生成全局唯一ID的方法汇总

    在服务器系统开发时,为了适应数据大并发的请求,我们往往需要对数据进行异步存储,特别是在做分布式系统时,这个时候就不能等待插入数据库返回了取自动id了,而是需要在插入数据库之前生成一个全局的唯一id,使用全局的唯一id,在游戏服务器中,全局唯一的id可以用于将来合服方便,不会出现键冲突.也可以将来在业务增长的情况下,实现分库分表,比如某一个用户的物品要放在同一个分片内,而这个分片段可能是根据用户id的范围值来确定的,比如用户id大于1000小于100000的用户在一个分片内.目前常用的有以下几种:

  • Java贪吃蛇游戏完善版

    很认真的写的一个java版的贪吃蛇游戏,图形界面,支持菜单操作,键盘监听,可加速,减速,统计得分,设定运动速度,设定游戏背景颜色等!应该没有Bug了,因为全被我修改没了. 下面是项目各包及类的层次关系: 游戏的主要运行界面截图如下: 下面是部分代码,详细源码见此链接:贪吃蛇源码下载 Snake类: package com.huowolf.entities; import java.awt.Color; import java.awt.Graphics; import java.awt.Point

  • C语言实现小猫钓鱼游戏

    本文实例为大家分享了C语言实现小猫钓鱼游戏的具体代码,供大家参考,具体内容如下 #include<stdio.h> #include<time.h> #include<string.h> #include<stdlib.h> #include<windows.h> typedef struct { int data[3600]; int col[3600]; int top; } stack; typedef struct { int data[

  • java桌球小游戏 小球任意角度碰撞

    本文实例为大家分享了java桌球小游戏的具体代码,供大家参考,具体内容如下 import javax.swing.*; import java.awt.*; public class BallGame extends JFrame { /** *继承swing里面的窗口类 */ //加载图片 Image ball = Toolkit.getDefaultToolkit().getImage("images/ball.jpg.png");/*得到系统默认的工具包*/ Image desk

  • java实现猜拳游戏

    本文实例为大家分享了java实现猜拳游戏的具体代码,供大家参考,具体内容如下 package com.farsight.session7; import java.util.Scanner; /** * 根据输入的数字,判断数组strs的值 然后进行逻辑判断 */ public class 猜拳 { public static void main(String[] args) { String[] strs = { "石头", "剪刀", "布"

  • java实现连连看游戏

    本文实例为大家分享了java实现连连看游戏的具体代码,供大家参考,具体内容如下 代码会实现共享的,这个是截图 代码: package com.lr.bean; import java.util.Scanner; import java.util.Random; import com.lr.bean.Point; public class Link{ public static void main(String[] args){ Scanner sc=new Scanner(System.in);

  • java弹幕小游戏1.0版本

    java 弹幕小游戏的最初版本,供大家参考,具体内容如下 最近在学习javaSE,根据b站视频老师的讲解,也参考了他的代码,做了一个弹幕小游戏,也增添了一些自己的代码进去,因为只是最简单的游戏体,以后会慢慢做完整,所以如果有错误,或者代码不够整洁的话,可以帮我改正,谢谢啦. 父类 import java.awt.*; public class GameObject { //游戏物体的父类 Image img; double x,y; int speed = 3; int width,height

随机推荐