使用存储一副扑克牌,实现洗牌功能。

本文介绍了一个使用Java实现的扑克牌生成与洗牌的算法。通过定义Poker类来表示每张扑克牌的颜色和点数,利用LinkedList集合存储生成的扑克牌,并通过随机数生成器进行洗牌操作,最后按规律展示洗好的扑克牌。此算法适用于游戏开发中需要随机生成扑克牌的场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import java.util.LinkedList;
import java.util.Random;

class Poker {
	String color;
	String point;

	public Poker(String color, String point) {
		super();
		this.color = color;
		this.point = point;
	}

	@Override
	public String toString() {
		return "{" + color + point + "}";
	}
}

public class Puke {
	public static void main(String[] args) {
		LinkedList list = getPuke();
		changePuke(list);
		showPuke(list);
	}

	// 交换扑克牌的位置
	public static void changePuke(LinkedList list) {
		// 创建随机数对象
		Random random = new Random();
		for (int i = 0; i < 100; i++) {
			// 随机产生两个索引值
			int index1 = random.nextInt(list.size());
			int index2 = random.nextInt(list.size());
			// 根据索引值去除两张牌
			Poker p1 = (Poker) list.get(index1);
			Poker p2 = (Poker) list.get(index2);
			list.set(index1, p2);
			list.set(index2, p1);
		}
	}

	// 有规律的显示扑克牌
	public static void showPuke(LinkedList list) {
		for (int i = 0; i < list.size(); i++) {
			System.out.print(list.get(i) + "\t");
			if (i % 10 == 9) {
				System.out.println();
			}
		}
	}

	// 生成扑克牌
	public static LinkedList getPuke() {
		// 集合用于存储扑克牌对象
		LinkedList list = new LinkedList();
		// 定义数组存储所有的花色和点数
		String[] colors = { "黑桃", "红桃", "梅花", "方块" };
		String[] points = { "A", "2", "3", "4", "5", "6", "7", "8", "9", "10", "J", "Q", "K" };
		for (int i = 0; i < colors.length; i++) {
			for (int j = 0; j < points.length; j++) {
				list.add(new Poker(colors[i], points[j]));
			}
		}
		return list;
	}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值