BRONZE
BRONZE 등급의 판매자 자료

[자료구조] HashTable을 이용한 Spell Check Dictionary 프로그램

인하대학교 자료구조 다섯번째 과제물입니다. 각각의 문제에 대한 소스코드(주석포함) 및 실행파일이 압축되어있습니다. Hash Table을 이용하여 작성한 Spell Check 프로그램입니다. 프로그램이 실행되면 주어진 파일 “words.txt”에서 단어를 추출하여 해쉬테이블에 입력하며, 이를 통해 사용자로부터 입력받은 인풋값을 테이블로부터 검색합니다. 비슷한 단어를 입력할경우, 테이블 안의 비슷한 단어를 추천합니다. 자세한 문제내용은 아래와 같습니다. 교과서 페이지 384-387의 해쉬테이블을 이용하여 다음과 같은 spell check 프로그램을 작성하시오. 프로그램이 실행되면 주어진 파일 “words.txt”에서 단어를 추출하여 해쉬테이블에 입력한다. 이때 해쉬 테이블의 사이즈는 3001로 하고 중복된 단어는 입력하지 않는다. 프로그램의 인터페이스는 다음과 같다. Enter your selection (1: New Search, 2: Delete Word, 3: Size, 4: Quit): 1 Enter a word: very Given word “very” is in the dictionary!! Enter your selection (1: New Search, 2: Delete Word, 3: Size, 4: Quit): 1 Enter a word: veri Given word “veri” is not in the dictionary!! We have the following similar words: verb, very Do you want to insert “veri” into the dictionary? (y, n): n Enter your selection (1: New Search, 2: Delete Word, 3: Size, 4: Quit): 1 Enter a word: ik Given word “ik” is not in the dictionary!! We have the following similar words: is, it Do you want to insert “ik” into the dictionary? (y, n): y Given word “ik” has been inserted into the dictionary. Enter your selection (1: New Search, 2: Delete Word, 3: Size, 4: Quit): 2 Enter a word: ik Given word “ik” has been deleted from the dictionary. Enter your selection (1: New Search, 2: Delete Word, 3: Size, 4: Quit): 3 The dictionary has 1000 words. Enter your selection (1: New Search, 2: Delete Word, 3: Size, 4: Quit): 4 Bye!! 단어 추천은 영문 소문자만 사용한다.
압축파일
최초등록일 2009.04.08 최종저작일 2008.10
[자료구조] HashTable을 이용한 Spell Check Dictionary 프로그램
  • 미리보기

    소개

    인하대학교 자료구조 다섯번째 과제물입니다.
    각각의 문제에 대한 소스코드(주석포함) 및 실행파일이 압축되어있습니다.

    Hash Table을 이용하여 작성한 Spell Check 프로그램입니다.
    프로그램이 실행되면 주어진 파일 “words.txt”에서 단어를 추출하여 해쉬테이블에 입력하며,
    이를 통해 사용자로부터 입력받은 인풋값을 테이블로부터 검색합니다.
    비슷한 단어를 입력할경우, 테이블 안의 비슷한 단어를 추천합니다.

    자세한 문제내용은 아래와 같습니다.

    교과서 페이지 384-387의 해쉬테이블을 이용하여 다음과 같은 spell check 프로그램을 작성하시오.

    프로그램이 실행되면 주어진 파일 “words.txt”에서 단어를 추출하여 해쉬테이블에 입력한다. 이때 해쉬 테이블의 사이즈는 3001로 하고 중복된 단어는 입력하지 않는다.

    프로그램의 인터페이스는 다음과 같다.

    Enter your selection (1: New Search, 2: Delete Word, 3: Size, 4: Quit): 1
    Enter a word: very
    Given word “very” is in the dictionary!!

    Enter your selection (1: New Search, 2: Delete Word, 3: Size, 4: Quit): 1
    Enter a word: veri
    Given word “veri” is not in the dictionary!!
    We have the following similar words: verb, very
    Do you want to insert “veri” into the dictionary? (y, n): n
    Enter your selection (1: New Search, 2: Delete Word, 3: Size, 4: Quit): 1
    Enter a word: ik
    Given word “ik” is not in the dictionary!!
    We have the following similar words: is, it
    Do you want to insert “ik” into the dictionary? (y, n): y
    Given word “ik” has been inserted into the dictionary.

    Enter your selection (1: New Search, 2: Delete Word, 3: Size, 4: Quit): 2
    Enter a word: ik
    Given word “ik” has been deleted from the dictionary.

    Enter your selection (1: New Search, 2: Delete Word, 3: Size, 4: Quit): 3
    The dictionary has 1000 words.

    Enter your selection (1: New Search, 2: Delete Word, 3: Size, 4: Quit): 4
    Bye!!

    단어 추천은 영문 소문자만 사용한다.

    컴파일 실행환경

    Visual Studio 2008

    본문내용

    #include <iostream>
    #include <fstream>
    #include <string>
    #include "HashTable.h"

    using namespace std;

    #define SIZE 3001 // Hash Table 크기
    #define BUF_SIZE 80 // 입력값을 받는 버퍼 크기
    #define KEY_WEIGHT 83 // Hash Key 계산을 위한 가중치

    unsigned long makeKey(char str[BUF_SIZE]); // Hash에 insert 하기 위해 가중치를 부여한 키를 생성
    void ShowSimilarWord(char inp[BUF_SIZE]); // 입력한 단어와 비슷한 단어를 출력
    unsigned long pow(int x, int y); // x의 y승을 계산 (Key값 생성시 가중치 부여를 위해 사용)

    HashTable<unsigned long, char*> Hash(SIZE); // Hash Table

    int main()
    {
    int menu; // 메뉴입력
    unsigned long key; // 버퍼의 Key값 계산
    char yn; // y or n 선택
    bool quit = false; // while문 종료변수
    ifstream words; // word단위 입력파일스트림

    char buf[BUF_SIZE]; // 파일 입력 버퍼
    char inbuf[BUF_SIZE]; // 사용자 입력 버퍼

    words.open("words.txt");

    // word 단위로 파일을 읽어 버퍼에 저장후, 중복되지 않는 단어 Hash Table에 추가
    while(!words.eof()) {
    words >> buf;
    key = makeKey(buf);
    if( Hash.find(key) == NULL )
    Hash.insert(key,buf);
    }

    참고자료

    · (Data Structures and Algorithms in C++, Goodrich, Tamassia, Mount - WILEY)
  • 자료후기

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

    해피캠퍼스 FAQ 더보기

    꼭 알아주세요

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