Генерирование покерных рук для n количества игроков (пять карт каждая)

StackOverflow https://stackoverflow.com/questions/9351625

  •  27-10-2019
  •  | 
  •  

Вопрос

Проблема: Напишите программу Deal.java, который принимает аргумент командной строки n и печатает N Poker Hands (пять карт каждая) от перетасованной колоды, отделенной пустыми линиями.

Что я имею:

public static void main(String[] args)
{
    int N = Integer.parseInt(args[0]);


    String[] suit = { "Clubs", "Diamonds", "Hearts", "Spades" };
    String[] rank = 
    { 
        "2", "3", "4", "5", "6", "7", "8", "9", "10", 
        "Jack", "Queen", "King", "Ace" 
    };

    // initialize cards in a deck
    String[] deck = new String[suit.length * rank.length];
    for (int i = 0; i < rank.length; i++)
        for (int j = 0; j < suit.length; j++)
            deck[rank.length*i + j] = rank[i] + " of " + suit[j];

    // shuffle deck
    int d = deck.length;
    for (int i = 0; i < d; i++)
    {
        int r = i + (int) (Math.random() * (d-i));
        String temp = deck[r];
        deck[r] = deck[i];
        deck[i] = temp;
    }

    // repeat for N number of people
    for (int t = 0; t < N; t++)
    {
        // print 5 random cards
        for (int i = 0; i < 5; i++)
            System.out.print(deck[i] + " ");
        System.out.println();
    }   


} 

Кто -нибудь может сказать мне, что я здесь делаю не так? Я получаю ошибки arrayIndexoutofboundsexceptions, не уверен, почему. Это проблема из упражнений из моей книги, а не домашней работы.

Это было полезно?

Решение

Я предполагаю, что вы получаете исключение массивов-индекса из-за бок на этой линии:

deck[rank.length*i + j] = rank[i] + " of " + suit[j];

где вы, должно быть, имели в виду это:

deck[suit.length*i + j] = rank[i] + " of " + suit[j];

Другие советы

В дополнение к ошибке индекса, обнаруженной Ruakh, вы печатаете ту же руку N Времена:

// repeat for N number of people
for (int t = 0; t < N; t++)
{
    // print 5 random cards
    for (int i = 0; i < 5; i++)
        System.out.print(deck[i] + " ");
    System.out.println();
}

Чтобы распечатать разные руки, используйте другую переменную индекса,

// repeat for N number of people
int j = 0
for (int t = 0; t < N; t++)
{
    // print 5 random cards
    for (int i = 0; i < 5; i++, j++)
        System.out.print(deck[j] + " ");
    System.out.println();
}   

Я не вижу, в чем проблема, кажется, работает нормально, постарайтесь дать некоторые дополнительные подробности.

То, что вы должны улучшить, это:

Проверьте, что параметр устанавливается в начале правильно:

public static void main(String[] args)
{
    int N = Integer.parseInt(args[0]);

String[] suit = { "Clubs", "Diamonds", "Hearts", "Spades" };
String[] rank = 
{ 
    "2", "3", "4", "5", "6", "7", "8", "9", "10", 
    "Jack", "Queen", "King", "Ace" 
};

    if(N < 0 || N > suit.length * rank.length)
      throw new IllegalArgumentException("A number between 0 and " + suit.length * rank.length + "should be provided as argument");
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top