본문 바로가기

자작 프로그램

문자열 빈도 프로그램

336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.


#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <conio.h>
#include <memory.h>

int main()
{
 char buffer[128]; // 입력 버퍼

 size_t arrayCount = 0; // 입력받은 문자열 수
 char ** arrayPtr = NULL; // 입력받은 모든 문자열 배열

 size_t checkCount = 0; // 중복 목록 수
 char ** checkPtr = NULL; // 중복 목록
 int * checkCnt = NULL; // 각 문자열별 빈도 수

 int check = 0; // 중복된 거 찾으면 1, 아니면 0

 size_t i = 0, j = 0; // 인덱스 변수

 do
 {
  gets(buffer); // 입력

  if(strcmp(buffer, "0") != 0) // "0"이 아니라면?
  {
   // 입력받은 문자열 배열에 추가한다
   arrayPtr = (char **)realloc(arrayPtr, (++arrayCount) * sizeof(char *)); // 행 한 개 추가
   arrayPtr[arrayCount - 1] = (char *)calloc(strlen(buffer) + 1, sizeof(char)); // 문자 수만큼 열 추가

   strcpy(arrayPtr[arrayCount - 1], buffer); // 입력받은 문자열을 배열에 복사
  }
 } while(strcmp(buffer, "0") != 0);

 // 중복 검사
 for(i = 0; i < arrayCount; i++) // 입력 받은 문자열에서 검색
 {
  check = 0;
  for(j = 0; j < checkCount; j++) // 중복 목록에서 검색
  {
   if(strcmp(arrayPtr[i], checkPtr[j]) == 0) // 중복 목록에 있는 것이 또 검색되었으면
   {
    check = 1;
   }
  }

  if(check == 0) // 여지껏 보지 못한 새로운 문자열
  {
   // 중복 목록 테이블에 행 하나 추가
   checkCnt = (int *)realloc(checkCnt, (checkCount + 1) * sizeof(int));
   checkPtr = (char **)realloc(checkPtr, (checkCount + 1) * sizeof(char *));

   // 중복 목록 테이블에 듣보잡 문자열 추가
   checkPtr[checkCount] = (char *)calloc(strlen(arrayPtr[i]) + 1, sizeof(char));
   strcpy(checkPtr[checkCount], arrayPtr[i]);

   checkCnt[checkCount] = 0; // 빈도 = 1로 초기화
   checkCount++;
  }
 }

 // 이렇게 해서 checkPtr에는 중복되지 않는 문자열 목록이 있습니다.

 // 이제 이 표를 갖고 각 문자열의 출현 빈도를 구하죠
 for(i = 0; i < arrayCount; i++)
 {
  for(j = 0; j < checkCount; j++)
  {
   if(strcmp(arrayPtr[i], checkPtr[j]) == 0) // 중복된 거 찾았으면
    checkCnt[j]++; // 빈도 증가
  }
 }

 printf("분석 결과.\n\r");
 for(i = 0; i < checkCount; i++)
  printf("%s == %d회\n\r", checkPtr[i], checkCnt[i]);


 // 마무리

 free(checkCnt);

 for(i = 0; i < checkCount; i++)
  free(checkPtr[i]);
 free(checkPtr);

 for(i = 0; i < arrayCount; i++)
  free(arrayPtr[i]);
 free(arrayPtr);

 printf("끝.\n\r");
 _getch();
 return 0;
}

문자 "0"을 입력받을 때까지 계속 문자열을 입력 받아서 그 빈도를 구하는 프로그램입니다.
그냥 심심해서 만들어 봤습니다. 필요한 분들 쓰세요. 저는 또 구상중임 ㅎㅎ

'자작 프로그램' 카테고리의 다른 글

간단한 C# LINQ 식 예제  (0) 2011.03.20
문자열 크로스 예제  (0) 2011.03.05
FindFirstFile, FindNextFile, FindClose 예제  (0) 2011.02.28
대/소문자 변환 예제  (0) 2011.02.27
완전 간단 회원 관리 프로그램  (0) 2011.02.16