今天突然想起来以前看书的时候看见过一个编程题,要求是生成一副扑克牌并且模拟一下发牌的动作。
这个问题对很多人来说已经不是问题了,但是还是难倒了我这个刚入门的初学者。当初这个问题让我头疼的地方就是怎么去得到一个随机不重复的数组。
上网查了一查,这个其实有很多种思路。
例如:在这里就列出了Java实现随机不重复的三种思路http://www.javaeerun.com/jr_1378708438508.html
1 本身这个数组是按照顺序排放的,然后我们把这个数组里面数据的顺序打乱,再从第一个元素开始逐个获取
2 本身这个数组是按照顺序排放的,然后我们随机的从里面抽取元素发出去。
3 通过随机数直接生成随机的元素,然后比对数组里面是否有相同的元素,比对通过就放进去。
就按照做一做吧
首先是扑克牌类Card:
package com.javaeerun.demo.carddemo; public class Card { private String assortment; // 花色 private int number; // 数值 public static final String CARD_ASSORTMENT[] = { "Spade", "Heart", "Diamond", "Club", "Red Joker", "Black Joker" }; // 黑桃 红桃 方片 梅花 大王 小王 public Card(String assortment, int number) { super(); this.assortment = assortment; this.number = number; } public String getAssortment() { return assortment; } public void setAssortment(String assortment) { this.assortment = assortment; } public int getNumber() { return number; } public void setNumber(int number) { this.number = number; } @Override public String toString() { return "Card [assortment=" + assortment + ", number=" + number + "]"; } }
接下来是Main:
package com.javaeerun.demo.carddemo; import java.util.LinkedList; import java.util.List; public class Main { public static void main(String[] args) { Main main=new Main(); List<Card> cardList = main.createCardList(); //获取一个按照顺序排列的扑克牌,一共54张 while(cardList.size()>0){ //只要list里面有元素就取出来 int i=(int)(Math.random()*cardList.size()); System.out.println(cardList.get(i).toString()); cardList.remove(i); //把获得的元素从list里面删除 } } public List<Card> createCardList(){ //这个方法获取一个按照顺序排列的扑克牌 List<Card> cardList = new LinkedList<Card>(); for (int i = 0; i < 4; i++) { for (int j = 1; j < 14; j++) { cardList.add(new Card(Card.CARD_ASSORTMENT[i], j)); } } cardList.add(new Card(Card.CARD_ASSORTMENT[4], 0)); cardList.add(new Card(Card.CARD_ASSORTMENT[5], 0)); return cardList; } }
这样就完成了。