RadarURL

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

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

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

먼저 순열(permutation)과 조합(combination)에 대해 알아보자

 

 

 

순열 : 서로다른 n개 중 r개를 택하여 순서대로 나열하는 방법의 수 (표시 : nPr)

 

         n (n-1) (n-2) ..... (n-r+1)  : 10P3 이면 10x9x8                 즉 10! / 7! 이 되고,

                                                12P5 이면 12x11x10x9x8        즉 12! / 7! 이 된다.

 

         위 식에서 분자와 분모에 (n-r)!을 곱해주면

  

                         n!  

        nPr =   (n-r)!         이 된다.

 

 

 

 

중복순열 : 서로다른 n개 중 중복을 허용하여 r개를 선택해 순서대로 나열하는 방법의 수(표시 : nr )

 

         중복을 허용하므로, 각각의 선택에 대한 확률은 n이 된다.

 

         즉   n^r  (n의 r승)

 

 

 

 

 

조합 : 서로다른 n개 중 중복을 허용하여 r개를 선택하는것.  (표시 : nCr)

        순열과 비교했을때, 순서가 없는 것이 조합이다.

 

         즉, {a, b, c}에서 2개를 선택한다고 할때

         

              nPr = {ab, ac, bc, ba, ca, cb} 총 여섯개이지만,

              nCr = {ab, ac, bc} 이렇게 세가지가 된다.

 

 

         r개를 선택하는 순열에서 순서를 무시하게 되면,

 

         서로 같은 조합은 r!개가 나온다.

 

         그러므로

 

                                            n!   

       nCr =   nPr / r! =   r!(n-r)!         이 된다.

 

 

 

 

 

자 이제 본격적으로 C언어와 만나보도록 하자

 

 

 

위의 공식대로 계산할 경우 n의 값이 커짐에 따라서

 

n! 이 크게 늘어나 오버플로우(overflow)를 유발한다.

 

         n=13 일 때, 13! = 6,227,020,800 .       (4byte unsigned int 형의 최대값은 4,294,967,296)

 

 

자 이제, nCr을 점화식을 이용하여 표현해 보면.

 

 

 

                      n-r+1 

          nCr =   r     nCr-1  ( n>0 )  

          nCr = 1                 ( n=0 )   와 같이 나타낼 수 있다.

 

 

 

자 드디어 프로그래밍이다.

 

재귀함수를 이용하여 간단하게 nCr을 표현해보자.

 

 

 

 

long combi(int n, int r){

 

        if(n<0 || r<0){                                                         // 이 부분은 main 함수 내에서 처리하게되면,

                 printf(" n과 r은 양의 정수이어야 합니다");     // 실제로 꼭 필요한 부분은 아니지만,

                 break;                                                            // 예외를 생각하면서 코딩을 하는게

        }                                                                                // 좋을거라 생각한다.

        

        if(r==1){

                return 1;

        }else{

                return ((n-r+1)/r) * combi(n, r-1);

        }

}

       

 

 

 

덧글 : 재귀함수는 비교적 간단하게 함수를 구현할수 있다.

         위의 예에서 주석부분을 제외하면 실제로 combi() 함수는

         실제로 100글자를 넘지 않는다.

         하지만, 매번마다 함수를 호출하여 메모리를 잡아먹게 되므로,

         실제  재귀구조를 이용하는데에는 신중해야할 필요가 있다

 

출처 : http://blog.naver.com/pair00/120035649468

?

공부 게시판

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

  1. [공지] 공부 게시판 입니다.

    Date2003.08.18 By처누 Views931227
    read more
  2. 전수데이터를 생성하는 빠른 콤비나토리얼 프로그램 (Fast Combinatorial Programs Generating Total Data)

    Date2015.07.15 Category논문 ByJaeSoo Views672
    Read More
  3. 스코퍼스(Scopus) 지수

    Date2014.10.21 Category논문 ByJaeSoo Views886
    Read More
  4. [논문] Ubiquitous-City Integrated Authentication System (UCIAS) - Jae-Soo Jang, Hyung-Min Lim, Journal of Intelligent Manufacturing(JIM), February 2014, 장재수

    Date2014.02.21 Category논문 ByJaeSoo Views2061
    Read More
  5. [논문] 다중링크를 이용한 다양한 크기의 데이터 전송 (Data transmission of various size that use multiplex link) - 장재수,학위논문(석사), 숭실대학교 대학원 : 컴퓨터학과(일원) 컴퓨터통신 2003. 12

    Date2014.01.25 Category논문 ByJaeSoo Views2877
    Read More
  6. [논문] 조합과 순열 생성 알고리즘의 개선(Enhancement of Combination and Permutation Generation Algorithms) - 장재수,학위논문(박사), 숭실대학교 대학원 : 컴퓨터학과(일원) 컴퓨터통신 2013. 8

    Date2014.01.25 Category논문 ByJaeSoo Views2621
    Read More
  7. 제 논문에 실린 감사의 글입니다

    Date2013.06.12 Category논문 ByJaeSoo Views7217
    Read More
  8. 박사학위논문을 끝내고 감사하는 마음의 글

    Date2013.06.12 Category논문 ByJaeSoo Views5939
    Read More
  9. 로그(Log)에 대하여..

    Date2013.06.10 Category논문 ByJaeSoo Views3668
    Read More
  10. Excel 엑셀, 상용 로그, 자연 로그(LOG) 구하기 계산 함수; Common, Natural Logarithm

    Date2013.06.10 Category논문 ByJaeSoo Views6940
    Read More
  11. 논문 투고 과정

    Date2013.06.07 Category논문 ByJaeSoo Views4836
    Read More
  12. 수리과학 영어논문 작성법

    Date2013.06.07 Category논문 ByJaeSoo Views5237
    Read More
  13. 논문 작성과 형식 - 1.10 퇴고와 기타사항

    Date2013.05.19 Category논문 ByJaeSoo Views4847
    Read More
  14. 논문 작성과 형식 - 1.8 표와 그림

    Date2013.05.19 Category논문 ByJaeSoo Views5759
    Read More
  15. 논문 작성과 형식 - 1.9 주와 참고문헌의 처리

    Date2013.05.19 Category논문 ByJaeSoo Views4410
    Read More
  16. 논문 작성과 형식 - 1.7 인용과 인증

    Date2013.05.19 Category논문 ByJaeSoo Views4678
    Read More
  17. 논문 작성과 형식 - 1.6 논문 작성시 문장의 형식

    Date2013.05.19 Category논문 ByJaeSoo Views6252
    Read More
  18. 논문 작성과 형식 - 1.5 논문의 내용 전개

    Date2013.05.19 Category논문 ByJaeSoo Views4922
    Read More
  19. 논문 작성과 형식 - 1.4 논문의 내용구성

    Date2013.05.19 Category논문 ByJaeSoo Views5171
    Read More
  20. 논문 작성과 형식 - 1.3 논문의 작성의 개요

    Date2013.05.19 Category논문 ByJaeSoo Views5210
    Read More
  21. 논문 작성과 형식 - 1.2 학술논문의 형식

    Date2013.05.19 Category논문 ByJaeSoo Views6558
    Read More
Board Pagination Prev 1 2 3 4 Next
/ 4


즐겨찾기 (가족)

JAESOO's HOMEPAGE


YOUNGAE's HOMEPAGE


장여은 홈페이지


장여희 홈페이지


장여원 홈페이지


즐겨찾기 (업무)

알리카페 홀릭

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

말레이시아 KL Sentral 한국인 GuestHouse


즐겨찾기 (취미)

어드민아이디

유에코 사랑회

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

JServer.kr

제이서버 메타블로그

재수 티스토리


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

재수 강의 홈페이지


한소리


VTMODE.COM


숭실대 인공지능학과


숭실대 통신연구실


베너