malloc 초기화는 어떻게 하나요?
찬바리
질문 제목 :malloc 초기화는 어떻게 하나요?질문 요약 :프로그램은 작동하긴 하는데....
[초기화로
a[i].entry = (char*) malloc(1);이렇게 한 후에...뒷 부분에 가서 다시..a[i].entry = (char*) malloc(strlen(ptoken)+1);이렇게 하면 안돼요.]
라고 하는데 무엇이 문제인가요????
혼자 생각해봤을 때는 동적할당을 못받으면 \0을 반환하는 것 같은데 저는 초기화로 \0을 넣었거든요 그 이유 맞나요? 아무튼어떻게 초기화해야하나요?
질문 내용 :
// 프로그램 목적 : 입력 text 파일을 OPEN해서 Tokenization 수행 (strtok 함수 이용)// 각 token에 대해… -Lexicon에 추가하고 // -전체 DOC에서 나타난 빈도가 얼마인지? // (빈도별, 알파벳 순서별로 출력) #include stdio.h#include stdlib.h#include string.h
// 구조체 선언typedef struct { char *entry; int freq;} dict;
// 순서를 바꿔주는 swap함수void swap(dict *x, dict *y){ dict temp;
temp = *x; *x = *y; *y = temp;
return;}
int main(int argc, char *argv[]) // 입출력 파일의 이름을 main함수의 argument로 받음{ FILE *f1, *f2; char *delimiter = ,.:;?!\n; dict lex[1000]; // 구조체 배열 선언 char *ptoken; char line[1024]; int i=0, j=0, temp=0, total=1, num=0;
// 입력 에러 확인 if(argc!=3) { printf(Input Error); exit(1); }
// 파일열기 if ((f1 = fopen(argv[1], r)) == NULL) { printf(File Open Error(1)\n); exit(1); }
// 구조체의 필드들을 초기화 for(i=0; i1000; i++) { lex[i].entry = (char *)malloc(1); // 초기화를 위한 malloc if(lex[i].entry == NULL) { // null check printf(Malloc Error\n); exit(1); } strcpy(lex[i].entry, \0); lex[i].freq = 0; }
// fgets로 한줄을 받아서 strtok함수로 tokenization수행하고 lexicon에 추가 while(fgets(line, 1024, f1) != 0) { ptoken = strtok(line, delimiter); while(ptoken != NULL) { *ptoken = tolower(*ptoken); // 대소문자 normalization temp = 0; for(i=0; itotal; i++) { if(strcmp(lex[i].entry, ptoken) == 0) { // 일치하면 lex[i].freq++; // 기존에 저장되어 있는지 찾아서 빈도 하나 증가시킴 temp++; // temp를 증가시켜 아래 if문을 수행하지 못함 break; // 저장하고 break로 반복문 빠져나옴 } } if(temp == 0) { // 위의 for문을 돌리고서도 일치하는게 없다면 for(i=0; itotal; i++) { if(strcmp(lex[i].entry, \0) == 0) { lex[i].entry = (char*) malloc(strlen(ptoken) + 1);// string을 저장할 구조체의 필드를 malloc을 이용하여 만듦 if(lex[i].entry == NULL) { // null check printf(Malloc Error\n); exit(1); } strcpy(lex[i].entry, ptoken); // 단어 저장 lex[i].freq = 1; // 한번 나왔으므로 빈도 하나 증가 num++; // 단어의 갯수 저장 break; // 저장되어있는 곳까지만 비교하고 break로 반복문 빠져나옴 } } } total++; ptoken = strtok(NULL, delimiter); } }
// 파일 열기 if ((f2 = fopen(argv[2], w)) == NULL) { printf(File Open Error(2)\n); exit(1); }
// 빈도별로 출력 for(i=0; inum-1; i++) { // bubble sorting for(j=0; jnum-i-1; j++) { if (lex[j].freq lex[j+1].freq) { swap(&lex[j], &lex[j+1]); // swap함수로 내림차순 정렬 } } }
for(i=0; inum; i++) { printf(%s\t\t\t\t%d\n, lex[i].entry, lex[i].freq); // printf함수로 출력 }
printf(==========================================================\n);
// 알파벳 순서별로 출력 for(i=0; inum-1; i++) { // bubble sorting for(j=0; jnum-i-1; j++) { if (strcmp(lex[j].entry, lex[j+1].entry) 0) { // strcmp함수의 return값을 이용하여 swap(&lex[j], &lex[j+1]); } } } for(i=0; inum; i++) { printf(%s\t\t\t\t%d\n, lex[i].entry, lex[i].freq); // printf함수로 출력 }
printf(==========================================================\n);
// 빈도별로 출력 for(i=0; inum-1; i++) { // bubble sorting for(j=0; jnum-i-1; j++) { if (lex[j].freq lex[j+1].freq) { swap(&lex[j], &lex[j+1]); } } }
for(i=0; inum; i++) { fprintf(f2, %s\t\t\t\t%d\n, lex[i].entry, lex[i].freq); // fprintf함수로 출력 }
printf(==========================================================\n);
// 알파벳 순서별로 출력 for(i=0; inum-1; i++) { // bubble sorting for(j=0; jnum-i-1; j++) { if (strcmp(lex[j].entry, lex[j+1].entry) 0) { swap(&lex[j], &lex[j+1]); } } } for(i=0; inum; i++) { fprintf(f2, %s\t\t\t\t%d\n, lex[i].entry, lex[i].freq); // fprintf함수로 출력 }
for(i=0; inum; i++) { // 메모리 해제 free(lex[i].entry); }
fclose(f1); // 파일 닫기 fclose(f2); // 파일 닫기
return 0;}
질문 이렇게 하는거 맞나요... 처음 올리는 글이라 잘못된 점이 있으면 알려주세요
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2698938 | c언어 메모리질문 (3) | 나래 | 2025-06-21 |
2698909 | 서비스 요청 고객 관리 프로그램 짜는것좀 도와주세요ㅜㅜ (4) | 궁수자리 | 2025-06-21 |
2698882 | 프로그래밍좀 짜주세요 (3) | 황예 | 2025-06-21 |
2698855 | 카프-라빈 알고리즘 코딩 분석좀 도와주세요.. | 꽃봄 | 2025-06-20 |
2698829 | 학점계산기 (7) | MyWay | 2025-06-20 |
2698782 | 기초적인 함수 질문이요ㅠㅠㅠㅠ | 내담 | 2025-06-20 |
2698749 | 프로그램 짜던 도중 패닉입니다...ㅜ | 파랑 | 2025-06-19 |
2698719 | 조건부컴파일 질문입니다.~ (2) | 큐트 | 2025-06-19 |
2698693 | 재귀 함수 에러 | 바닐라 | 2025-06-19 |
2698673 | 고민이있는데 들어좀주세요!! (1) | 초코맛캔디 | 2025-06-19 |
2698644 | 1부터 n까지의 합을 구하는데 엄청긴숫자의 합을 구할때는 어떻게 해야하나요? (4) | 슬우 | 2025-06-18 |
2698616 | 다른 함수로 안넘어갑니다..;;; | 도1도캣 | 2025-06-18 |
2698587 | 배열하다 막혀서... (3) | WhiteCat | 2025-06-18 |
2698559 | 문자열을 비우는방법 (2) | 하늘 | 2025-06-18 |
2698528 | 착하고 친절한 선생씌구해염~ㅋㅋ (4) | 옆집언니야 | 2025-06-17 |
2698502 | 자료구조 큐 | 캔서 | 2025-06-17 |
2698477 | 실행화면 배경문의요 | 선아 | 2025-06-17 |
2698430 | 변수의 값이 저장이 않되네요;; (4) | 피네 | 2025-06-16 |
2698404 | C#을 배울려고 하는데 C나 C++을 알아야 하나요 ?? (1) | 신당 | 2025-06-16 |
2698342 | 프로그램 질문점녀 (4) | 데빌의눈물 | 2025-06-16 |