RadarURL

논문
2012.10.22 01:11

nCr[combination] 구현하기

조회 수 5676 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

GetCombination함수에 n, r의 자연수를 입력하면 coll에 조합방식을 문자열로 반환한다.
함수 리턴값은 조합의 개수이다.

GetCombination();
combination();

두 개의 함수를 구현하고 GetCombination을 call~!!


int GetCombination(int n, int r, CStringArray *coll)
{
      int count = 0;

      CString strTemp = L"";
      CString temp = L"";

      int *c= new int[r+1];   // c에 dynamic array를 이용해 입력받은 r값으로 array의 크기정해줌

 for( int i=1;i<r+1;i++)   // s[0]=1,s[1]=2,..........,s[r-1]=r 이런식으로 값을 할당해줌.
 {        // lexicographic order에 따라 첫번째 combination값을 만들어줌
         c[i-1]=i;
 }

 for( int i=0;i<r;i++)
 { 
       temp.Format( _T("%i"), c[i] - 1 );
       strTemp = strTemp + temp;
 }
       coll->Add( strTemp );
       count++;

 int k;
 k=combination(n,r);    // k는 n,r에대해 가질수 있는 총 Combination갯수를 구한 값

 for( int h=2;h<k+1;h++)
 {
      int m=r-1;
      int max_val=n;

  while(c[m]==max_val)
  {
         m=m-1;     // maximumvalue 값을 만족하는 배열 위치보다 -1작은 위치 m을 구함
         max_val=max_val-1;  // 예를들어 n=6 r=4일때 1256 이란 값이 들어오면 5와 6은 while구문
  }       // 내에서 max_value만족 따라서 m=1이란 5,6앞의 2의 배열의 위치 값을 반환함

  c[m]=c[m]+1;    // c[m]에값에 +1을 해준다.
  for(int j=m+1;j<r;j++)  // while구문이 실행될 경우 실행 c[m+1]부터 c[r-1]까지
  {       // 그 앞에 수의 +1값을 자신이 가짐 ex) c[m+1]=c[m]+1. c[m+2]=c[m+1]+1
   c[j]=c[j-1]+1;   // cobination값은 permutation에서 swap을 사용하는것과 같은것이 필요 없다.
  }       // 위의 m의 값을 구한후 그 구한 m을 위치로 갔는 배열 c[m]값 이후로 그 앞에 값의
         // +1씩만 해주만 lexicographic order을 만족하는 combination값이 나옴
  strTemp = L"";
  for(int i=0;i<r;i++)
  { 
   temp.Format( _T("%i"), c[i] - 1 );
   strTemp = strTemp + temp;
  }
  coll->Add( strTemp );
  count++;
 }

 delete [] c;
 return count;
}


int combination(int n, int r)
{
         int i;
         int kup = 1;          // 분자
         int kdown = 1;        // 분모

         for(i=n;i>n-r;i--)    //  분자 계산
             kup *= i;

        for(i=r;i>0;i--)       //  분모에 계산
              kdown *= i;

         return kup/kdown;
}

 

출처 : http://ultragom.tistory.com/entry/nCrcombination-구현하기

?

공부 게시판

공부에 도움되는 글을 올려주세요.

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
공지 [공지] 공부 게시판 입니다. 처누 2003.08.18 927915
1406 네트워크 iPTiME 같은 일반 공유기로 SK,LG,KT등 iPTV 시청하기 file JaeSoo 2012.10.20 4885
1405 네트워크 ipTIME 공유기로 WoL 기능 활용하기 file JaeSoo 2012.10.20 3447
» 논문 nCr[combination] 구현하기 JaeSoo 2012.10.22 5676
1403 경제 재산세에 대한 정보 JaeSoo 2012.10.22 3501
1402 경제 재산세 계산하는 방법 JaeSoo 2012.10.22 5590
1401 경제 재산세의 정의와 계산방법 file JaeSoo 2012.10.22 4482
1400 경제 주택 재산세 계산방법, 아파트 재산세 자동 계산기 file JaeSoo 2012.10.22 12985
1399 경제 무이자 3개월의 환산 피킹율 JaeSoo 2012.10.23 3592
1398 경제 '블로그로 돈버는' 블로그 광고 사이트 6가지 소개!! [BlogTip] file JaeSoo 2012.10.24 4786
1397 건강 벤조피렌이란? file JaeSoo 2012.10.25 3128
1396 웹광고 알라딘 TTB 입맛대로 설정하기 file JaeSoo 2012.10.26 7412
1395 웹광고 알라딘의 Thanks to Blogger[TTB] 란? file JaeSoo 2012.10.26 3394
1394 웹광고 구글 AdSnse를 차단하는 방법 JaeSoo 2012.10.26 4498
1393 자동차 후방 블랙박스가 필요한 이유 JaeSoo 2012.10.26 6494
1392 자동차 HD 블랙박스 적당한 메모리 용량 JaeSoo 2012.10.26 8414
1391 자동차 차량용 블랙박스 달고 보험료 할인받으세요 file JaeSoo 2012.10.26 6280
1390 자동차 자동차블랙박스/ 상시전원케이블을 믿었다간 낭패 file JaeSoo 2012.10.26 10437
1389 경제 혜담카드로 쿠팡이나 티몬도 할인 가능한가요? JaeSoo 2012.10.26 5944
1388 자동차 자동차보험 제대로 보상 받으려면... (차량가액 및 연식, 부속품가액, 차량 형식과 세분 등) JaeSoo 2012.10.26 6407
1387 자동차 블랙박스 보험할인 3% 받기 JaeSoo 2012.10.27 6315
Board Pagination Prev 1 ... 49 50 51 52 53 54 55 56 57 58 ... 124 Next
/ 124


즐겨찾기 (가족)

JAESOO's HOMEPAGE


YOUNGAE's HOMEPAGE


장여은 홈페이지


장여희 홈페이지


장여원 홈페이지


즐겨찾기 (업무)

알리카페 홀릭

숭실대 컴퓨터 통신연구실 (서창진)

말레이시아 KL Sentral 한국인 GuestHouse


즐겨찾기 (취미)

어드민아이디

유에코 사랑회

아스가르드 좋은사람/나쁜사람

JServer.kr

제이서버 메타블로그

재수 티스토리


즐겨찾기 (강의, 커뮤니티)

재수 강의 홈페이지


한소리


VTMODE.COM


숭실대 인공지능학과


숭실대 통신연구실


베너