BRONZE
BRONZE 등급의 판매자 자료

어셈블리어를 이용한 Binary Search 구현

바이너리 서치를 어셈블리어로 구현한 것입니다.. 제가 어셈블리어 수업 들을때 기말 레포트로 작성하 였던 겁니다..
4 페이지
한컴오피스
최초등록일 2004.12.20 최종저작일 2004.12
어셈블리어를 이용한 Binary Search 구현
  • 미리보기

    소개

    바이너리 서치를 어셈블리어로 구현한 것입니다..
    제가 어셈블리어 수업 들을때 기말 레포트로 작성하
    였던 겁니다..

    컴파일 실행환경

    바이너리 서치의 기본구조를 어셈블리어로 작성하였
    습니다..
    기본 주어진 데이터 내에서 찾고,주어진 데이터 범위
    를 벗어날 경우 에러 메세지를 출력합니다..
    C++이나 C언어로 구현하는것은 쉬우나 어셈블리어로
    구현하는 것은 어렵더군요..

    본문내용

    CODE SEGMENT
    ASSUME CS:CODE
    ASSUME DS:DATA

    MOV AX, DATA
    MOV DS, AX

    CALL FIRST_MESSAGE ;***BINARY Search ( data: A B C D E F G H I J K )***라는 문자열을 출력하는 프로시져를 CALL
    CALL KEY_MOVE ;스택을 이용하여 커서를 다음줄 맨 앞으로 이동시키는 프로시저를 CALL한다.
    CALL KEY_MOVE ;즉 한칸 띄우는 역할을 한다.

    CALL INPUT_CHAR ;Input character:라는 문자를 출력하는 프로시저를 CALL

    MOV AH, 01H ; 키보드에서 문자를 입력받고 입력받은 내용을 보여주는 인터럽트.
    INT 21H ;AH에 입력받아서 AL에서 리턴.(여기서 Search하고자 하는 데이터를 키보드로 입력받는다)
    CALL KEY_MOVE ;스택을 이용하여 커서를 다음줄 맨 앞으로 이동시키는 프로시저를 CALL한다.
    CALL BINSEAR ;Binary Search를 구현한 프로시저를 CALL한다.


    ;***BINARY Search ( data: A B C D E F G H I J K )***라는 문자열을 출력하는 프로시져
    FIRST_MESSAGE PROC NEAR
    MOV BX, OFFSET AA1 ;BX에 변수 AA1의 주소값을 넣는다.
    MOV CX, 51 ;문자의 갯수가 51개 이므로 51번 카운터를 돌려서 데이터를 출력해야한다..
    AGAIN: MOV DL, [BX] ;그래서 51을 CX에 넣는다.
    MOV AH, 02H ;BX에 저장된 내용을 출력하는 인터럽트.
    INT 21H
    INC BX ;BX+1 을 해주면서
    LOOP AGAIN ;카운터에 저장된 51번 동안 루프를 돌린다. 즉 변수AA1에 저장된 51개의 문자가 출력된다.
    RET ;프로시저 실행이 끝나면 원래 위치로 돌아간다.
    FIRST_MESSAGE ENDP


    ;Input character: 라는 문자열을 출력하는 프로시져
    INPUT_CHAR PROC NEAR
    MOV BX, OFFSET AA2 ;BX에 변수 AA2의 주소값을 넣는다.
    MOV CX, 17 ;문자의 갯수가 17개 이므로 17번 카운터를 돌려서 데이터를 출력해야한다..
    AGAIN1: MOV DL, [BX] ;그래서 17을 CX에 넣는다.
    MOV AH, 02H ;BX에 저장된 내용을 출력하는 인터럽트.
    INT 21H
    INC BX ;BX+1 을 해주면서
    LOOP AGAIN1 ;카운터에 저장된 17번 동안 루프를 돌린다. 즉 변수AA2에 저장된 17개의 문자가 출력된다.
    RET ;프로시저 실행이 끝나면 원래 위치로 돌아간다.
    INPUT_CHAR ENDP


    ;스택을 이용하여 커서를 다음줄 맨 앞으로 이동시키는 프로시저
    KEY_MOVE PROC NEAR
    PUSH AX ;AX값을 스택에 저장한다.
    MOV DL, 0AH
    MOV AH, 02H
    INT 21H ;커서를 다음줄 맨 왼쪽으로 옮긴다.
    MOV DL, 0DH
    MOV AH, 02H
    INT 21H
    POP AX ;AX값을 스택에서 꺼내서 AX로 옮긴다.

    참고자료

    · 없음
  • 자료후기

      Ai 리뷰
      지식판매자가 제공한 자료는 정보가 풍부하고, 내용이 명확하게 정리되어 있어 과제를 작성하는데 큰 도움이 되었습니다. 매우 추천할 만한 자료입니다!
    • 자주묻는질문의 답변을 확인해 주세요

      해피캠퍼스 FAQ 더보기

      꼭 알아주세요

      • 자료의 정보 및 내용의 진실성에 대하여 해피캠퍼스는 보증하지 않으며, 해당 정보 및 게시물 저작권과 기타 법적 책임은 자료 등록자에게 있습니다.
        자료 및 게시물 내용의 불법적 이용, 무단 전재∙배포는 금지되어 있습니다.
        저작권침해, 명예훼손 등 분쟁 요소 발견 시 고객센터의 저작권침해 신고센터를 이용해 주시기 바랍니다.
      • 해피캠퍼스는 구매자와 판매자 모두가 만족하는 서비스가 되도록 노력하고 있으며, 아래의 4가지 자료환불 조건을 꼭 확인해주시기 바랍니다.
        파일오류 중복자료 저작권 없음 설명과 실제 내용 불일치
        파일의 다운로드가 제대로 되지 않거나 파일형식에 맞는 프로그램으로 정상 작동하지 않는 경우 다른 자료와 70% 이상 내용이 일치하는 경우 (중복임을 확인할 수 있는 근거 필요함) 인터넷의 다른 사이트, 연구기관, 학교, 서적 등의 자료를 도용한 경우 자료의 설명과 실제 자료의 내용이 일치하지 않는 경우

    찾으시던 자료가 아닌가요?

    지금 보는 자료와 연관되어 있어요!
    왼쪽 화살표
    오른쪽 화살표
    문서 초안을 생성해주는 EasyAI
    안녕하세요. 해피캠퍼스의 방대한 자료 중에서 선별하여 당신만의 초안을 만들어주는 EasyAI 입니다.
    저는 아래와 같이 작업을 도와드립니다.
    - 주제만 입력하면 목차부터 본문내용까지 자동 생성해 드립니다.
    - 장문의 콘텐츠를 쉽고 빠르게 작성해 드립니다.
    - 스토어에서 무료 캐시를 계정별로 1회 발급 받을 수 있습니다. 지금 바로 체험해 보세요!
    이런 주제들을 입력해 보세요.
    - 유아에게 적합한 문학작품의 기준과 특성
    - 한국인의 가치관 중에서 정신적 가치관을 이루는 것들을 문화적 문법으로 정리하고, 현대한국사회에서 일어나는 사건과 사고를 비교하여 자신의 의견으로 기술하세요
    - 작별인사 독후감
    해캠 AI 챗봇과 대화하기
    챗봇으로 간편하게 상담해보세요.
    2025년 07월 16일 수요일
    AI 챗봇
    안녕하세요. 해피캠퍼스 AI 챗봇입니다. 무엇이 궁금하신가요?
    3:54 오전