java集合类的数据结构灵活应用

package cn.itcast_03;

import java.util.ArrayList;
import java.util.Collections;

/*
 * 模拟斗地主洗牌和发牌
 *
 * 分析:
 *   A:创建一个牌盒
 *   B:装牌
 *   C:洗牌
 *   D:发牌
 *   E:看牌
 */
public class PokerDemo {
 public static void main(String[] args) {
  // 创建一个牌盒
  ArrayList<String> array = new ArrayList<String>();

  // 装牌
  // 黑桃A,黑桃2,黑桃3,...黑桃K
  // 红桃A,...
  // 梅花A,...
  // 方块A,...
  // 定义一个花色数组
  String[] colors = { "♠", "♥", "♣", "♦" };
  // 定义一个点数数组
  String[] numbers = { "A", "2", "3", "4", "5", "6", "7", "8", "9", "10",
    "J", "Q", "K" };
  // 装牌
  for (String color : colors) {
   for (String number : numbers) {
    array.add(color.concat(number));
   }
  }
  array.add("小王");
  array.add("大王");

  // 洗牌
  Collections.shuffle(array);

  // System.out.println("array:" + array);

  // 发牌
  ArrayList<String> fengQingYang = new ArrayList<String>();
  ArrayList<String> linQingXia = new ArrayList<String>();
  ArrayList<String> liuYi = new ArrayList<String>();
  ArrayList<String> diPai = new ArrayList<String>();

  for (int x = 0; x < array.size(); x++) {
   if (x >= array.size() - 3) {
    diPai.add(array.get(x));
   } else if (x % 3 == 0) {
    fengQingYang.add(array.get(x));
   } else if (x % 3 == 1) {
    linQingXia.add(array.get(x));
   } else if (x % 3 == 2) {
    liuYi.add(array.get(x));
   }
  }

  // 看牌
  lookPoker("风清扬", fengQingYang);
  lookPoker("林青霞", linQingXia);
  lookPoker("刘意", liuYi);

  lookPoker("底牌", diPai);
 }

 public static void lookPoker(String name, ArrayList<String> array) {
  System.out.print(name + "的牌是:");
  for (String s : array) {
   System.out.print(s + " ");
  }
  System.out.println();
 }
}

测试多次
输出:

风清扬的牌是:小王 ♦8 ♥10 ♦5 ♣Q ♥4 ♣7 ♣8 ♠9 ♦A ♠4 ♥7 ♠2 ♦6 ♠7 ♥8 ♣9
林青霞的牌是:♦Q ♥5 ♥9 ♠A ♠6 ♣3 ♠Q ♦7 ♦10 ♠K ♦K ♣K ♥3 ♠10 ♠8 ♥6 ♠5
刘意的牌是:♥2 ♠3 ♥A ♠J ♥Q ♣J ♦J ♣4 ♥K ♦4 ♣6 ♣5 ♥J ♦3 ♦2 大王 ♦9
底牌的牌是:♣A ♣2 ♣10
输出:风清扬的牌是:♦2 ♠7 ♥9 ♦9 ♥3 ♥7 ♠A ♠Q ♣2 ♣4 ♠J ♦4 ♦A ♣5 ♠3 ♥K ♦5
林青霞的牌是:♥10 ♦8 ♥2 ♣Q ♣8 ♠K ♦3 ♠4 ♣7 ♠6 ♠9 ♦Q ♠10 ♣3 ♥5 小王 ♣J
刘意的牌是:♥4 ♠2 ♦J ♦7 ♦K ♥8 ♣6 ♥J ♣10 ♥A ♦10 ♠8 ♠5 ♥Q ♣9 ♥6 ♣K
底牌的牌是:♦6 大王 ♣A

先保存在这里,慢慢领悟

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值