Turbo-C
C++Builder  |  Delphi  |  FireMonkey  |  C/C++  |  Free Pascal  |  Firebird
볼랜드포럼 BorlandForum
 경고! 게시물 작성자의 사전 허락없는 메일주소 추출행위 절대 금지
터보-C 포럼
Q & A
FAQ
팁&트릭
강좌/문서
자료실
Lua 게시판
볼랜드포럼 홈
헤드라인 뉴스
IT 뉴스
공지사항
자유게시판
해피 브레이크
공동 프로젝트
구인/구직
회원 장터
건의사항
운영진 게시판
회원 메뉴
북마크
볼랜드포럼 광고 모집

C/C++ Q/A
[1898] Re:52장의 카드를 섞는 방법
임문환 [mhlim] 2851 읽음    2003-01-28 04:06
#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장의 카드를 뽇아낼 수 있는 방법이 없을까요? 고수님들의 자세한 답변을 부탁드립니다.

+ -

관련 글 리스트
1895 52장의 카드를 섞는 방법 c++ 1752 2003/01/28
3832     Re:52장의 카드를 섞는 방법 임문환 1635 2003/01/28
1907     Re:52장의 카드를 섞는 방법 뚱뚜루 1614 2003/01/28
1898     Re:52장의 카드를 섞는 방법 임문환 2851 2003/01/28
1900         Re:Re:52장의 카드를 섞는 방법 c++ 1525 2003/01/28
1897     Re:52장의 카드를 섞는 방법 - 제가 쓰는 해결방법 SteelHeart 1766 2003/01/28
1899         Re:Re:52장의 카드를 섞는 방법 - 제가 쓰는 해결방법 c++ 2118 2003/01/28
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.