[C언어]텍스트파일을 입력받아서 텍스트파일내 단어를 검색하는 프로그램입니다.

pjwdark의 이미지

#include
#include
#include
#include

//문자열의 최대 길이
#define MAXLENGTH 30
//텍스트파일 이름의 최대 길이
#define MAXNAME 15

//단어의 갯수와 라인을 표시할 스택
struct Number{
int nFrequency;
int nLines;
};
typedef struct Number NUMBERS;

//트리노드 구조체
struct TreeNode{
char cData[MAXLENGTH];
NUMBERS *ptNumbers;
struct TreeNode *ptLeft;
struct TreeNode *ptRight;
};
typedef struct TreeNode TREENODE;

//트리 구조체
struct Tree{
int nTreeSize;
TREENODE *ptRoot;
};
typedef struct Tree TREE;

void initTree(TREE *ptTree);
void storeTree(TREE *ptTree, FILE *pfFile);
void storeTreeSub(TREE *ptTree, char *cWord);
void searchWord(TREE *ptTree, char strWord[]);

void main()
{
int i=0;
FILE *pfFile;
TREE *ptTree;
char strFileName[MAXNAME];
char strText;
char strWord[MAXLENGTH];
char cCommand;

ptTree = (TREE *)malloc(sizeof(TREE));

initTree(ptTree);

printf("File name(No file extension) : ");
gets(strFileName);
fflush(stdin);
strcat(strFileName, ".txt");
pfFile = fopen(strFileName, "r");

if(pfFile == NULL)
{
printf("file open error!\n");
return;
}

storeTree(ptTree, pfFile);

printf("=============================== Text File ===============================\n");
while(true)
{
strText = fgetc(pfFile);
if(strText == EOF) break;
putchar(strText);
}
printf("\n");
printf("=========================================================================\n");
fclose(pfFile);

printf("S : Search, Q : Quit\n");

do{
//커맨드 입력
printf("Command : ");
cCommand = getch();
cCommand = toupper(cCommand);
putch(cCommand);
printf("\n");

switch(cCommand)
{
case 'S' : //search
printf("Search Word : ");
gets(strWord);
fflush(stdin);
searchWord(ptTree, strWord);
break;

case 'Q' : //Quit
break;

default : //wrong command
printf("\nWrong command. Try again\n");
}
}while(cCommand != 'Q');
}

//트리 초기화
void initTree(TREE *ptTree)
{
ptTree->nTreeSize = 0;
ptTree->ptRoot = NULL;
}

//텍스트 파일을 트리에 저장
void storeTree(TREE *ptTree, FILE *pfFile)
{
char cWord[MAXLENGTH];

while(feof(pfFile))
{
int i = 0;
while(cWord[i] != '\n')
{
cWord[i] = fgetc(pfFile);
cWord[i] = tolower(cWord[i]);
if(cWord[i] == '\0')
storeTreeSub(ptTree, cWord);
i++;
}
}
}

//텍스트 파일을 트리에 저장하는 함수
void storeTreeSub(TREE *ptTree, char *cWord)
{
TREENODE *ptTempNode;

ptTempNode = (TREENODE *)malloc(sizeof(TREENODE));

ptTempNode->ptLeft = NULL;
ptTempNode->ptLeft = NULL;
strcpy(ptTempNode->cData, cWord);

//트리가 비어있는 경우
if(ptTree->nTreeSize = 0)
ptTree->ptRoot = ptTempNode;

printf("%s\n", ptTempNode->cData);

//트리에 자료가 있는 경우

}

일단 파일명을 입력받아서 텍스트파일의 내용을 출력하는 부분은 끝냈습니다만.
텍스트파일에 사용된 단어들을 이진트리에 저장하고 싶은데 이 부분이 잘 안되네요.

이 부분만 어떻게 처리하면 어떻게든 될거 같긴한데 말이죠...

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.