|
#include <stdlib.h>
#include <time.h>
void ShuffleCards(int cards[][2]);
int main()
{
int i,j;
int cards[4][13]; //실제 카드
int shuffledCards[52][2]; //섞인 카드
int gamersCards[3][7][2]; //게이머가 3명일 때 각 게이머의 카드들
int gamersCardCount[3]={0}; //각 게이머에게 분배된 카드 수
int allotedCardCount=0; //shuffledCards 중 이미 게이머에게 분배된 카드의 수
//이 부분에서 cards[][]에 일련번호를 부여하고
//카드를 섞은 다음
ShuffleCards(shuffledCards);
//이 부분에서 각 게이머에게 카드를 분배합니다.
//게이머가 3명이라고 칩시다.
//그런데 처음에 각 게이머에게 몇 장을 주더라... 4장을 준다고 칩시다.
//그러면
for(i=0 ;i<4 ;i++){
for(j=0 ;j<3 ;j++){
gamersCards[j][i][0]=shuffledCards[allotedCardCount][0];
gamersCards[j][i][1]=shuffledCards[allotedCardCount][1];
gamersCardCount[j]=i;
allotedCardCount++;
}
}
//그리고 이 다음 게임 진행은 어떻게 하는지 포커 자체를 잘 몰라서 못하겠군요.
return 0;
}
void ShuffleCards(int cards[][2])
{
bool used[4][13]={false};
int usedCount=0;
int i;
randomize();
while(usedCount<52){
i = random(52);
if(used[i/13][i%13]==false){
used[i/13][i%13]=true;
cards[usedCount][0]=i/13;
cards[usedCount++][1]=i%13;
}
}
}
c++ 님이 쓰신 글 :
: 스페이드 A,2,3,...J,Q,K
: 다이아 A,2,3,...J,Q,K
: 클로바 A,2,3,...J,Q,K
: 하트 A,2,3,...J,Q,K
:
: 위의 52장의 카드을 중복되지 않게 섞는 방법을 알고 싶습니다. 알고리즘도 괜찮고 소스면 더욱 좋습니다. rand 함수를 사용하는 것까지는 알겠는데 중복되지 않게 52장의 카드를 뽇아낼 수 있는 방법이 없을까요? 고수님들의 자세한 답변을 부탁드립니다.
|