#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 |