カードのデッキをシャッフルするカードのデッキのコードを書いています。私はコードをテストしましたが、それが実際に正しく実行されているはずのことを実行しているかどうかは本当にわかりませんか?どう思いますか?
これは、シャッフルメソッドのコードです。
public void shuffle()
{
for( int x = myDeck.size(); x > 0 ; x--)
{
Random rn = new Random();
int index1 = rn.nextInt(52);
Card c = myDeck.remove(index1);
myDeck.add(c);
}
}
私の出力はその数がシャッフルされているように見えますが、スペードのハートなどのカードの名前ではありません、
たとえば、これはコードをテストしたときの出力です。
Deuce of spades
Seven of spades
Eight of spades
Ace of spades
Three of hearts
Five of hearts
Six of hearts
Seven of hearts
Nine of hearts
Ten of hearts
Queen of hearts
King of hearts
Ace of hearts
Seven of diamonds
Eight of diamonds
Jack of diamonds
King of diamonds
Three of clubs
Seven of clubs
Nine of clubs
Jack of clubs
Queen of clubs
King of clubs
Ace of clubs
Queen of spades
Deuce of clubs
Three of spades
Nine of diamonds
Four of spades
Four of clubs
Deuce of hearts
Jack of spades
Ten of clubs
Six of diamonds
Jack of hearts
Six of clubs
Four of diamonds
Five of diamonds
Ace of diamonds
Four of hearts
Nine of spades
Ten of spades
Five of spades
Three of diamonds
Six of spades
Five of clubs
Deuce of diamonds
Eight of hearts
King of spades
Ten of diamonds
Eight of clubs
Queen of diamonds
いつも繰り返される名前があるように。シャッフルのポイントはそれを混ぜることなので間違っていますか?
これが実際の質問です。カードをプレイするときは、もちろん、デッキをシャッフルすること、つまり、カードがランダムな順序で配られるように物事を配置することが重要です。これを達成する方法はいくつかあります。1つの戦略は、デッキからランダムにカードを繰り返し選び、それを最後に移動することです。次のコードは、Randomクラス(オンラインコースの「ArrayLists」セクションの8ページで会った)を使用して、そのような「選択して最後に移動」操作を実行します。
Random rn = new Random();
int index1 = rn.nextInt( 52 );
Card c = myDeck.remove( index1 );
myDeck.add( c );
デッキを効果的にシャッフルするには、この操作を何度も(たとえば500回)繰り返す必要があります。単一のRandomオブジェクトとforループを使用してmyDeckをシャッフルするDeckクラスの新しいインスタンスメソッドshuffleを作成します。mainメソッドを適切に変更した後、それを使用して新しいコードをテストします。
だから私の主な質問は:私はこれを間違っているのですか?