• AI글쓰기 2.1 업데이트
  • AI글쓰기 2.1 업데이트
  • AI글쓰기 2.1 업데이트
  • AI글쓰기 2.1 업데이트
BRONZE
BRONZE 등급의 판매자 자료

[알고리즘 프로젝트] 단어 유사도 검색기 최종보고서

해시 알고리즘 과 단어파편분석 알고리즘을 이용한 단어유사성 검색기입니다. 파일입출력 기능도 포함되어있습니다. 프로젝트 파일은 따로 업로드되어있습니다.
20 페이지
한컴오피스
최초등록일 2015.04.02 최종저작일 2014.12
20P 미리보기
[알고리즘 프로젝트] 단어 유사도 검색기 최종보고서
  • * 본 문서는 한글 2005 이상 버전에서 작성된 문서입니다. 한글 2002 이하 프로그램에서는 열어볼 수 없으니, 한글 뷰어프로그램(한글 2005 이상)을 설치하신 후 확인해주시기 바랍니다.

    미리보기

    소개

    해시 알고리즘 과 단어파편분석 알고리즘을 이용한
    단어유사성 검색기입니다.
    파일입출력 기능도 포함되어있습니다.


    프로젝트 파일은 따로 업로드되어있습니다.

    목차

    1. 연구내용 및 추진체계
    1) 수행계획서와 실제구현의 차이점
    2) 일정표

    2. 사용된 알고리즘과 기능
    1) 2차원 Hasing을 통한, DataBase 삽입과 검색.
    2) 파편화비교 Algorithm을 통한 유사도산출
    3) 유사도 순위 선정 Algorithm
    4) 문자열 검색 예외처리
    5) Gotoxy함수를 이용한 직관적 UI
    6) 색상효과로 인한 명확한 정보전달

    3. 구현내용
    1) 2차원 Hasing을 통한 삽입
    2) 2차원 Hasing을 통한, 검색.
    3) 단어를 파편화한 후, 파변배열에 저장하는 Algorithm
    4) 파편비교 유사도 산출 Algorithm
    5) 유사도 순위 설정
    6) Gotoxy함수를 이용한 직관적 UI
    7) 명확한 정보출력을 위한 색상헤더
    8) 검색어 예외처리 기능

    4. 실행결과
    1) 초기화면
    2) 설정화면
    3) 검색화면(초기화면)
    4) 종료화면( 종료 탭 선택시 )

    5. 분석
    1) hash_table 삽입
    2) hash_table 검색
    3) 문자열 파편화 & 저장
    4) 단어 유사도 산출
    5) 단어유사도 순위결정
    6) 입력값 예외처리

    6. 결론

    본문내용

    본 팀은 유사도비교 Algorithm을 구상하는 가장 많은 노력을 하였다. 일반적으로 문자열을 구성하는 문자의 순서와 동일성을 비교한다면 가장 높은 정확성을 지닐 것이다.하지만, 그럴 경우 시간복잡도가 너무 높아진다는 단점이 있다. 만약, 문자의 순서를 무시하고 구성문자의 동일성만 비교한다면, 가령 “Love(사랑)” 이라는 단어와 “vole(들쥐)” 라는 단어를 같은 단어라고 인식하는 문제가 발생하게 된다.본 팀은 유사도비교의 정확성과 시간복잡도라는 두 마리 토끼를 잡기위하여, “단어파편화 비교“라는 방식의 Algorithm을 설계 및 구현하였다. 이 알고리즘은 해단 문자열을 구성하는 단어들을 파현화시켜 동일한 파편이 존재하는지에 대한 비교를 통해, 유사도를 산출하는 Algorithm이다.

    <중 략>

    검색과정은 1-1에서 설명한 Hashing 과정의 역순이다. 다만, 검색 알고리즘에 있어서본 팀의 알고리즘이 효율적인 시간복잡도를 지니는 이유는, Null값 참조 유무에 따라,해당 검색어가 존재하는 지 없는지를 빠르게 판단할 수 있다는 점이다.해당 검색어의 아스키코드에 Collision이 k번 발생하였을 경우, K+1 번의 조사과정 후반드시 검색을 완료하게 된다.(본 팀의 프로그램에서 평균 Collision은 100미만이다.)

    <중 략>

    상기 코드는 문자열비교 시, 산출된 유사도를 가지고 유사도 순위를 Update 시키Algorithm이다. Algorithm 설계는 항상 일반적인 경우를 고려해야한다는 점을 생각하여, 순위의 최대 MAX는 5이하이지만, 따로 MAX변수로 설정하여, MAX의 수에 의존 하지 않고 모든 경우에 순위가 유동적으로 변동되는 알고리즘을 설계하게 되었다.함수가 시작되면, 유사도와 문자열을 가진 노드를 생성한다. 그 뒤, 생성한 노드를 포인터 배열에 접근시켜 배열이 Null 경우 삽입, 배열에 있는 노드의 유사도와 비교 후, 포인터 지시를 변경시키는 과정을 가진다.공간복잡도의 효율성을 고려하여, 순위에 포함되지 않거나, 밀려나는 노드를 메모리 반환해주는 기능도 포함되어있다.

    참고자료

    · 천인국, (C언어로 쉽게 풀어 쓴)자료구조= Data structures in C(생능출판사, 2005)
    · 이상진, (열혈강의)자료구조: C로 만드는 자료구조와 적용 알고리즘 해설서(프리렉, 2010)
    · 윤성우, 열혈 C 프로그래밍(오렌지미디어, 2010)
    · 윤성우, 난 정말 C PROGRAMMING을 공부한 적이 없다구요(오렌지미디어, 2010)
    · http://www.c-language.wo.to/ ( C언어 길라잡이, 네이버 카페 )
    · http://cafe.naver.com/cafec ( C언어를 배우자, 네이버 카페 )
  • 자료후기

      Ai 리뷰
      지식판매자가 등록한 자료는 과제에 적용할 수 있는 유용한 내용이 많아, 큰 도움이 되었습니다. 앞으로도 많은 도움을 받을 수 있기를 기대합니다!
    • 자주묻는질문의 답변을 확인해 주세요

      해피캠퍼스 FAQ 더보기

      꼭 알아주세요

      • 자료의 정보 및 내용의 진실성에 대하여 해피캠퍼스는 보증하지 않으며, 해당 정보 및 게시물 저작권과 기타 법적 책임은 자료 등록자에게 있습니다.
        자료 및 게시물 내용의 불법적 이용, 무단 전재∙배포는 금지되어 있습니다.
        저작권침해, 명예훼손 등 분쟁 요소 발견 시 고객센터의 저작권침해 신고센터를 이용해 주시기 바랍니다.
      • 해피캠퍼스는 구매자와 판매자 모두가 만족하는 서비스가 되도록 노력하고 있으며, 아래의 4가지 자료환불 조건을 꼭 확인해주시기 바랍니다.
        파일오류 중복자료 저작권 없음 설명과 실제 내용 불일치
        파일의 다운로드가 제대로 되지 않거나 파일형식에 맞는 프로그램으로 정상 작동하지 않는 경우 다른 자료와 70% 이상 내용이 일치하는 경우 (중복임을 확인할 수 있는 근거 필요함) 인터넷의 다른 사이트, 연구기관, 학교, 서적 등의 자료를 도용한 경우 자료의 설명과 실제 자료의 내용이 일치하지 않는 경우
    문서 초안을 생성해주는 EasyAI
    안녕하세요 해피캠퍼스의 20년의 운영 노하우를 이용하여 당신만의 초안을 만들어주는 EasyAI 입니다.
    저는 아래와 같이 작업을 도와드립니다.
    - 주제만 입력하면 AI가 방대한 정보를 재가공하여, 최적의 목차와 내용을 자동으로 만들어 드립니다.
    - 장문의 콘텐츠를 쉽고 빠르게 작성해 드립니다.
    - 스토어에서 무료 이용권를 계정별로 1회 발급 받을 수 있습니다. 지금 바로 체험해 보세요!
    이런 주제들을 입력해 보세요.
    - 유아에게 적합한 문학작품의 기준과 특성
    - 한국인의 가치관 중에서 정신적 가치관을 이루는 것들을 문화적 문법으로 정리하고, 현대한국사회에서 일어나는 사건과 사고를 비교하여 자신의 의견으로 기술하세요
    - 작별인사 독후감
    해캠 AI 챗봇과 대화하기
    챗봇으로 간편하게 상담해보세요.
    2025년 09월 03일 수요일
    AI 챗봇
    안녕하세요. 해피캠퍼스 AI 챗봇입니다. 무엇이 궁금하신가요?
    3:38 오후