메뉴 건너뛰기

SAP 한국 커뮤니티

[요청]Binary Search의 원리에 대한 질문

수욕정이풍부지 2009.02.12 11:16 조회 수 : 3831

안녕하세요?


ABAP 4년차인데요..


늘상 사용하는 Binary Search이지만 ABAP에서의 근본적인 원리가 갑자기 궁금해져서 질문을 드립니다.


전산학과 출신이라서 기본적인 알고리즘은 알고 있습니다.


Search하고자 하는 필드의 순서대로 Sort를 한 후에


이진 트리를 이용하여 중간값과 찾고자하는 값을 비교하여 검색하기 때문에


대상건수가 많을수록 속도는 일반 Search에 비해서 기하급수적으로 빨라지겠죠..


예를 들어 1000 건을 대상으로 Search를 하게 되면


일반 Search는 1000/2  = n 이므로 평균 500번의 탐색속도를 가지게 될거고


Binary Search는 2ⁿ = 1000이므로 최대 10번 정도의 탐색속도를 가지게 되는 걸로 알고 있습니다.


 


그런데 프로그래밍을 하면서 일반 Search든 Binary Search든 중복되는 값이 있을때는


가장 첫번째 값을 찾아온다는 것은 이미 수많은 경험을 통해서 익히 알고 있습니다.


궁금한 것은 일반 Search는 순차적으로 Read하므로 위 결과가 당연하다고 생각되지만,


Binary Search는 중간값을 비교하는데 왜 항상 첫번째 값을 읽어오느냐 하는 것입니다.


 


아래와 같은 Internal Table이 있다고 가정하고 질문을 드리면


 


Index   A    B


--------------


  1       1    a  


  2       2    b


  3       3    c


  4       3    d


  5       4    e


  6       5    f


  7       6    g


 


위에서 Internal table은 A라는 필드로 이미 Sort가 되어 있는 상태입니다.


 


여기서 READ TABLE itab WITH KEY A = '3' BINARY SEARCH 라는 명령을 하게 되면


세번째 Index를 읽게 되고 B값은 'c'가 될 겁니다.


하지만 알고리즘 접근을 하게 되면 총 7건의 Record이므로 중간값인 4번째 index를


읽어서 B값은 'd'가 되어야 맞는게 아닌가 하는 의문이 문득 들었던 적이 있었거든요..


 


ABAP에서 Bianry Search를  할 때 알고리즘을 어떻게 적용해서 사용하는건지 알고 싶네요.


물론 실질적인 프로그래밍을 함에 있어서는 쓸데없는 질문이 될수도 있겠지만  궁금한 건 못참는 성격이라서.. ^^


다시 한 번 말씀드리지만 Search 결과를 물어보고자 하는게 아니라


중복값의 Search가 정확히 어떤 방식으로 이루어지는지 혹시 알고 계시면 답변 주시면 감사하겠습니다. 


다들 수고하세요~


 

번호 제목 글쓴이 날짜 조회 수
6235 <img src=2.gif>급해요 !!! 화면에 옵션설정 하는 방법좀 알려주세요 . 옵션창이 어딨는지는 압니다. 그림첨부해요 [12] file 오렌지겅주님 2010.08.05 3926
6234 [re] 잠금 엔트리에 대해서... [1] file sapjoy 2007.03.23 3923
6233 [요청]alv register_edit_event 메소드 사용!! [6] genius 2008.04.15 3921
6232 <b>[완료]</b>하위 레벨을 찾는 BOM 관련 펑션 사용 문의 [3] 행복한외계인 2007.12.11 3919
6231 <b>[완료]</b>":실행시오류 RAISE_EXCEPTION가(이) 발생했습니다" 원인을 모르겠음 [5] 도련님 2007.12.24 3912
6230 [요청]SAP 프린터시 에러가 뜹니다. 무엇이 문제인가요? [2] file 양키 2009.02.02 3902
6229 <b>[완료]</b>Carry out repairs in non-original system only if they are urgent???? [9] SD2 2008.11.20 3901
6228 sy-dynnr이 몬가여? [6] 정미영 2007.04.19 3897
6227 [요청]스마트 폼에서 바코드를 출력할 때, 페이지 포맷에 관해..... [3] Seph 2008.09.10 3892
6226 고객 위탁 재고 Table에 대한 질문 [1] 소주와 막걸리 2007.03.05 3881
6225 <img src=2.gif>테이블 Foreign Key 와 프로그램 관련 입니다. [1] aDam 2011.03.30 3874
6224 [요청]인터널 테이블을 이용한 필드 카탈로그를 가져올 때..... [5] 효방 ^-^ 2008.09.18 3865
6223 <img src=3.gif>[기초] 모듈풀과 실행가능 프로그램의 차이가 무엇인가요 ?? [8] 촌놈악마 2010.10.25 3861
6222 [요청]ALV GRID에서 EDIT기능 이용시 질문요~! [1] 풍운사랑 2008.06.30 3857
6221 <b>[완료]</b>smartform에서 새로운 page로 찍으려면 [7] file w 2007.12.04 3852
6220 <img src=3.gif>PROCESS ON VALUE-REQUEST. 서치헬프질문요 [3] 덩콘 2010.05.11 3836
» [요청]Binary Search의 원리에 대한 질문 [4] 수욕정이풍부지 2009.02.12 3831
6218 <img src=3.gif>숫자와문자로 조합된 text를 넣으면 숫자만 나오게 하는 펑션 있나요? [5] 기쁨 2010.10.06 3822
6217 [요청]like line of과 type line of 차이는? [5] 로미오 2008.09.01 3820
6216 [re] T-CODE SMW0 에 대해서 아시는분 없나요? [7] file sapjoy 2007.01.31 3819