炸金花实践练习

Poker类:表示一张扑克牌,包括花色(suit)和数字(rank)。提供了相应的构造方法、getter和setter。

java 复制代码
public class PokersPK {
	public class Poker {
	    private String suit;//花色
	    private int rank;//数字
	 
	    public Poker(String suit, int rank) {
	        this.suit = suit;
	        this.rank = rank;
	    }
	 
	    public String getSuit() {
	        return suit;
	    }
	 
	    public void setSuit(String suit) {
	        this.suit = suit;
	    }
	 
	    public int getRank() {
	        return rank;
	    }
	 
	    public void setRank(int rank) {
	        this.rank = rank;
	    }
	 
	    @Override
	    public String toString() {
	        return "{ "+suit+" "+rank+"}";
	    }
	}
	
	private static final String[] suits = {"♥","♣","♦","♠"};

buyPoker()方法:生成一副完整的扑克牌,包括四种花色("♥","♣","♦","♠")和数字(1 到 13)的组合,总共52张牌。

java 复制代码
public List<Poker> buyPoker(){
        List<Poker> pokers = new ArrayList<>();
        for (int i = 0; i < 4; i++) {
            for (int j = 1; j <= 13; j++) {
                Poker poker = new Poker(suits[i], j);
                pokers.add(poker);
            }
        }
        return pokers;
    }

shuffle(List<Poker> pokers)方法:对传入的扑克牌进行洗牌操作,即打乱牌的顺序。

java 复制代码
 public void shuffle(List<Poker> pokers){
        for (int i = pokers.size()-1; i > 0; i--) {
            Random random = new Random();
            int index = random.nextInt(i);
            swap(pokers,i,index);
        }
    }

swap(List<Poker> pokers, int i, int j)方法:交换扑克牌集合中的两张牌的位置。

java 复制代码
 private void swap(List<Poker> pokers, int i, int j){
        Poker tmp = pokers.get(i);
        pokers.set(i,pokers.get(j));
        pokers.set(j,tmp);
    }

game(List<Poker> pokers)方法:进行发牌操作,将洗好的扑克牌分成三份,每份五张。

java 复制代码
public List<List<Poker>> game(List<Poker> pokers){
        List<List<Poker>> hand = new ArrayList<>();
        List<Poker> hand1 = new ArrayList<>();
        List<Poker> hand2 = new ArrayList<>();
        List<Poker> hand3 = new ArrayList<>();
        hand.add(hand1);
        hand.add(hand2);
        hand.add(hand3);
 
        for (int i = 0; i < 5; i++) {
            for (int j = 0; j < 3; j++) {
                Poker removePoker = pokers.remove(0);
                hand.get(j).add(removePoker);
            }
        }
        return hand;
    }

main()方法:在主函数中实例化了一个PokersPK对象,购买了一副扑克牌,并展示了洗牌和发牌的过程。

java 复制代码
public static void main(String[] args) {
    	  PokersPK game = new PokersPK();
          List<Poker> pokers = game.buyPoker();
          System.out.println(pokers);
   
          //洗牌
          game.shuffle(pokers);
          System.out.println("洗牌:");
          System.out.println(pokers);
   
          //揭牌
          List<List<Poker>> hand = game.game(pokers);
          System.out.println("揭牌:");
          for (int i = 0; i < hand.size(); i++) {
              System.out.println("第 "+(i+1)+"个人的牌:"+hand.get(i));
          }
          System.out.println("剩下的牌");
          System.out.println(pokers);
      }

运行结果:

相关推荐
xmweisi12 分钟前
【华为】报文统计的技术NetStream
运维·服务器·网络·华为认证
十八朵郁金香14 分钟前
通俗易懂的DOM1级标准介绍
开发语言·前端·javascript
菜鸟蹦迪20 分钟前
八股文实战之JUC:ArrayList不安全性
java
2501_9032386520 分钟前
Spring MVC配置与自定义的深度解析
java·spring·mvc·个人开发
逻各斯31 分钟前
redis中的Lua脚本,redis的事务机制
java·redis·lua
计算机毕设指导633 分钟前
基于Springboot学生宿舍水电信息管理系统【附源码】
java·spring boot·后端·mysql·spring·tomcat·maven
计算机-秋大田40 分钟前
基于Spring Boot的兴顺物流管理系统设计与实现(LW+源码+讲解)
java·vue.js·spring boot·后端·spring·课程设计
计算机小白一个1 小时前
蓝桥杯 Java B 组之背包问题、最长递增子序列(LIS)
java·数据结构·蓝桥杯
DC_BLOG1 小时前
Linux-GlusterFS进阶分布式卷
linux·运维·服务器·分布式
yourkin6661 小时前
TCP...
服务器·网络·tcp/ip