我在洗牌两副牌时遇到问题。我使用二维数组创建了两个套牌。请记住,这些是要求。我还需要使用一种名为shuffle()的方法对它们进行洗牌,该方法接收1D数组并返回1D数组。
在洗牌两副牌后,我需要从第一副牌中挑选前两张牌,从第二副牌中挑选前两张牌,并检查它们是否匹配。以及获得结果所需的洗牌次数。
示例输出:
第1副牌中的两张完全匹配卡牌是:钻石王牌,俱乐部2张
第2副牌中的两张完全匹配卡牌是:钻石王牌,俱乐部2张
洗牌次数: 387
这是我们参与的项目的第二部分,下面是我试图解决这个问题的内容。
我尝试使用下面的代码创建套牌,这有效
int[][] deck = new int[2][52];
for (int i = 0; i <= deck.length - 1; i++) {
for (int j = 0; j < deck[i].length; j++) {
deck[i][j] = j;
}
}
我写了洗牌方法,但它似乎不起作用。
public static int[] shuffle(int[] deck) {
for(int i=0; i<deck.length; i++) {
int index = (int)(Math.random()* deck.length);
int temp = deck[i];
deck[i] = deck[index];
deck[index] = temp;
}
return deck;
}
下面的代码是本项目第一部分的原始代码,在对它进行洗牌并计算获得四个这样的代码之后,我们需要从一个甲板上打印四个这样的代码。
class Main {
public static void main(String[] args) {
String[] suit = { "Spades", "Hearts", "Diamond", "Clubs" };
String[] rank = { "Ace", "1", "2", "3", "4",
"5", "6", "7", "8", "9",
"10", "Jack", "Queen", "King" };
int rank1, rank2, rank3, rank4, suit1, suit2, suit3, suit4, count = 0;
int[] deck = new int[52];
for (int i = 0; i < deck.length; i++) {
deck[i] = i;
}
do {
count++;
for (int i = 0; i < deck.length; i++) {
int index = (int) (Math.random() * deck.length);
int temp = deck[i];
deck[i] = deck[index];
deck[index] = temp;
}
suit1 = deck[0] / 13;
suit2 = deck[1] / 13;
suit3 = deck[2] / 13;
suit4 = deck[3] / 13;
rank1 = deck[0] % 13;
rank2 = deck[1] % 13;
rank3 = deck[2] % 13;
rank4 = deck[3] % 13;
} while (rank1 != rank2 || rank2 != rank3 || rank3 != rank4);
System.out.println(" Four-of-kind cards: " + suit[suit1] + " of "
+ rank[rank1] + ", " + suit[suit2] + " of " + rank[rank2]
+ ", " + suit[suit3] + " of " + rank[rank3] + ", "
+ suit[suit4] + " of " + rank[rank4]
+ "\n Number of shuffled times: " + count);
}
}
结果应该再次如下所示。
示例输出:
来自卡组1的两张精确匹配卡是:钻石王牌,俱乐部2卡组2中的两张精确匹配卡牌是:钻石王牌,俱乐部2
洗牌次数: 387
精慕HU
相关分类