-11

コンピューター サイエンスのクラスで課題を提出する予定です (数週間前にこの質問を投稿しましたが、説明された方法は、私が行う予定のプログラムに適合しません)。私はすでにデッキをシャッフルして配るプログラムをここに持っています。

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

void shuffle( int [][ 13 ] );
void deal ( const int[][ 13 ], const char *[], const char *[] );


 int main()
 {
  const char *suit[4] ={"Hearts","Diamonds","Clubs","Spades"};
    const char *face[13] ={"Ace", "Duece", "Three", "Four", "Five", "Six", 
    "Seven", "Eight","Nine", "Ten", "Jack", "Queen", "King"};
    int deck[4][13] = {0};
    int row, column, card = 1;


    for( row = 0; row <= 3; row++ )
    {
        for(column = 0; column <= 12; column++)
            {
            deck[row][column] = card;
            card++;
            }
    }

        srand(time(0));
        shuffle(deck);
        deal(deck, face, suit);
    return 0;
 }

 void shuffle( int wDeck[][13] )
 {
    int row, column, randomColumn, randomRow, card = 1, counter1, counter2, hold;




    for( counter1 = 0; counter1 <= 3; counter1++) 
    {
        for(counter2 = 0; counter2 <= 12; counter2++)
            {
                randomColumn = rand() % 13;
                randomRow = rand() % 4;

                    hold = wDeck[counter1][counter2];
                    wDeck[counter1][counter2] = wDeck[randomRow][randomColumn]; 
                    wDeck[randomRow][randomColumn] = hold;
            }
       }
    }

 void deal( const int wDeck[][13], const char *wFace[], const char *wSuit[] )
{
  int card, row, column;

        for ( card = 1; card <= 52; card++ )
            for (row = 0; row <= 3; row++ )
                for ( column = 0; column <= 12; column++ )
                    if( wDeck[row][column] == card )
                    {
                    printf("%5s of %-8s%c",wFace[ column ], wSuit[row], card % 2 == 0 ? '\n' : '\t');
                    break;
                    }
}

ディール関数を変更して 5 枚のカードのポーカー ハンドをディールし、後で「ランク」のポーカー ハンド (ツー オブ ア カインド、フラッシュ) を確認することになっています。私の先生は、これを行うために別の二重スクリプト配列を作成することについて言及しましたが、私は別の方法でそれを行うことができました。問題は、現在のデッキ/シャッフルのセットアップを使用する必要があることです。誰かがこれを行う方法を説明できますか? 効率が悪くても、うまくいっていればいい。

4

1 に答える 1