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

C++빌더 Q&A
C++Builder Programming Q&A
[20226] 이렇게 하면 상당히 효율이 낮은 방법입니다.
김백일 [cedar] 1105 읽음    2002-07-19 10:24
최준호.스페로 님이 쓰신 글 :
: 진수.네모 님이 쓰신 글 :
: : 1에서 100 사이에서 난수를 발생 시키려 합니다.
: :
: : for(inti=0;i<100;i++)
: :     random(100);
: :
: : 하면 같은 숫자가 여러번 반복되는데.. 서로 겹치지 않게 하려면 어떻게 하면 좋을까요
: :
:
: 안녕하세요 스페로입니다.
:
: 폼에 메모하나랑 버튼 올려주시고
:
: 다음의 코드를 버튼 클릭 이벤트에 해주세요
:
: 0 - 9 까지의 중복되지 않는 숫자가 무순서로 됩니다.
:
:
:
:    int i=0,j,tmp;
:
:    int arr[10];
:
:    bool ok;
:
:    time_t t;
:
:    srand((unsigned) time(&t));
:
:    while(i<10){
:     tmp = rand() % 10;
:     ok = true;
:     for(j=0;j<10;j++){
:         if(arr[j] == tmp) {ok = false;}
:     }
:
:     if (ok) {arr[i++] = tmp;
:         Memo1->Lines->Add(IntToStr(tmp));
:     }
:    }

이렇게 하면 이중 루프가 돌아가므로 O(N^2) 가 됩니다.
N이 클 경우는 상당히 속도가 느려집니다. -_-;

저의 답글과 방태윤님의 코드로는 O(N)으로 해결할 수 있지요.



+ -

관련 글 리스트
20212 [질문] 난수발생에서 숫자가 겹치지 않게 하려면... 진수.네모 1444 2002/07/19
20221     Re:[질문] 난수발생에서 숫자가 겹치지 않게 하려면... 방태윤 2138 2002/07/19
20231         Re:Re:[질문] 좋은 코드 내요.. (냉무) 제라툴 1101 2002/07/19
20228         random_shuffle 알고리듬은 실제로 이렇게 구현되어 있습니다. 김백일 1701 2002/07/19
20217     random_shuffle 알고리듬을 사용하세요. 김백일 1238 2002/07/19
20214     Re:[질문] 난수발생에서 숫자가 겹치지 않게 하려면... 최준호.스페로 2632 2002/07/19
20226         이렇게 하면 상당히 효율이 낮은 방법입니다. 김백일 1105 2002/07/19
20213     Re:[질문] 난수발생에서 숫자가 겹치지 않게 하려면... 최종혁 1332 2002/07/19
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.