java基础之用linkedlist存储一副牌,完成洗牌功能

本文介绍了一个使用Java实现的扑克牌洗牌程序。通过LinkedList存储一副完整的扑克牌,并运用Random类实现随机洗牌功能。文章展示了如何创建牌类、初始化牌堆、生成正序牌堆及最终的洗牌过程。

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


import java.awt.List;import java.util.LinkedList;import java.util.Random;//用linklist存储一副牌,完成洗牌功能class card extends LinkedList{//可以不用继承String color;String num;public card(String color,String num){this.color=color;this.num=num;}//参数为数组的构造方法,此题用集合更方便,但是就是任性@Overridepublic String toString() {return this.color+this.num;//对tostring进行重写}}public class demo13 {public static void main(String[] args){String [] colors={"黑桃","红桃","梅花","方块"};String [] nums={"2","3","4","5","6","7","8","9","10","J","Q","K","A"};LinkedList list=new LinkedList();Random r=new Random();//card c= new card(colors,nums,colors.length,nums.length);for(int i=0;i<colors.length;i++){for(int j=0;j<nums.length;j++){String d1=colors[i];//一个一个赋值String n=nums[j];card c= new card(d1,n); list.offer(c);//入队 /* * {int size=list.size();for(int a=0;a<size;a++){System.out.println( list.poll());//出队}//System.out.println( list.poll()); * * 生成的正序扑克牌 * * * * */}}//随机洗牌Object[] d=list.toArray();//转换为数组,保存在数组中System.out.println( d.length);list.removeAll(list);while(list.size()<=52){int l=0;l=r.nextInt(d.length);list.offer(d[l]);}{int size=list.size();for(int a=0;a<size;a++){System.out.println( list.poll());//出队}//System.out.println( list.poll());}}}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值