#include <stdio.h> //#include <conio.h> #include <string.h> char word[201]; char cut_word[201][201]; char end[4]={'E', 'N', 'D', '\0'}; int cnt[201]={0}; void set_word(void); //word 배열을 초기화하는 함수 void set_cut_word(int a); //cut_word 배열을 초기화하는 함수 int cut(void); //단어로 끊어내는 함수 void line(int c); //알파벳 순으로 정렬하는 함수 int what(int a, int b); //어떤 것이 앞 순서인지 판단하는 함수 int main(void) { int c=0, i, k; while(1) { scanf(" %[^\n]s", word); //gets(word); c=cut(); if(c==-1) //END가 입력되면 종료 break; line(c); for(i=0; i<c; i++) { printf("%s : %d\n", cut_word[i], cnt[i]); } set_word(); //strset(word, ' '); for(i=0; i<c; i++) { set_cut_word(i); //strset(cut_word[i], ' '); cnt[i]=0; } } return 0; } void set_word(void) { int i=0; while(word[i]!='\0') { word[i++]=' '; } word[i]=' '; } void set_cut_word(int a) { int i=0; while(cut_word[a][i]!='\0') { cut_word[a][i++]=' '; } cut_word[a][i]=' '; } int cut(void) { int i=0, j=0, k, a, b; char temp[50]; for(k=0; ; k++) { if(word[k]==' ' || word[k]=='\0') { temp[j]='\0'; if(strcmp(temp, end)==0) //END가 입력되면 종료 return -1; else if(i>0) { b=0; for(a=0; a<i; a++) { if(strcmp(temp, cut_word[a])==0) //앞에 같은 단어가 있을 경우 { cnt[a]++; b=1; break; } } if(b==0) { cnt[i]++; strcpy(cut_word[i++], temp); } } else { cnt[i]++; strcpy(cut_word[i++], temp); } if(word[k]=='\0') //입력된 문자열이 끝남 break; j=0; k++; } if(word[k]!=' ') temp[j++]=word[k]; } return i; } void line(int c) { int i, j, aa, max; char temp[50]; for(i=0; i<c-1; i++) { max=i; if(cut_word[i][0]!=' ') { for(j=i+1; j<c; j++) { if(what(max, j)==1) //앞 단어가 더 뒷 순서일 경우 { max=j; } } if(max!=i) { strcpy(temp, cut_word[i]); strcpy(cut_word[i], cut_word[max]); strcpy(cut_word[max], temp); aa=cnt[i]; cnt[i]=cnt[max]; cnt[max]=aa; } } //printf("----------------------------\n"); } } int what(int a, int b) { int i; for(i=0; ; i++) { if(cut_word[a][i]>cut_word[b][i] || cut_word[b][i]=='\0') { //printf("%s > %s \n", cut_word[a], cut_word[b]); return 1; } else if(cut_word[a][i]<cut_word[b][i] || cut_word[a][i]=='\0') { //printf("%s > %s \n", cut_word[b], cut_word[a]); return 0; } } }
2018.01.02 18:35
정올 - 실력키우기 - 단어 세기(1516)
조회 수 1010 추천 수 0 댓글 0
번호 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|
공지 | 글쓰기는 하루 5개, 댓글은 10개만 가능합니다. | 좋은아빠되기 | 2019.02.15 | 568 |
공지 | 키보드 화살표값 출력 | 좋은아빠되기 | 2016.11.19 | 1343 |
공지 | 원하는 좌표에 값 출력하기 | 좋은아빠되기 | 2016.11.19 | 2652 |
공지 | Python(파이썬) 학습 자료 PDF 1 | 좋은아빠되기 | 2014.12.10 | 10712 |
공지 | dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) | 좋은아빠되기 | 2014.06.07 | 4987 |
공지 | DEV-C++ 기본 코드 | 좋은아빠되기 | 2013.06.19 | 8597 |
공지 | 무료 C++ 컴파일러(윈도우용) DEV-C++ | 좋은아빠되기 | 2013.06.18 | 19233 |
공지 | 이클립스 C++ 설치 파일들 | 좋은아빠되기 | 2013.06.18 | 38130 |
330 | 삼각형 넓이구하기.(승민) | 승민 | 2016.03.05 | 1008 |
329 | 반복문 몇번 하는지 초기치(승민) | 승민 | 2016.03.05 | 112 |
328 | for문(승민) | 승민 | 2016.03.05 | 92 |
327 | 홀수 짝수 for문(스민) | 승민 | 2016.03.05 | 555 |
326 | 1부터10까지 더하기(승민) | 승민 | 2016.03.05 | 591 |
325 | 2016-03-05 첫번째 | 뚜디 | 2016.03.05 | 1608 |
324 | 정올 반복제어문2 형성평가4 | 선우 | 2016.03.11 | 227 |
323 | 정올 반복제어문2 형성평가 6 | 선우 | 2016.03.11 | 284 |
322 | A 20번 반복해서 출력하기(승민) | 승민 | 2016.03.12 | 88 |
321 | 1부터 10까지 더하기 | 승민 | 2016.03.12 | 969 |
320 | 정올 반복제어문3 자가진단4 | 선우 | 2016.03.12 | 214 |
319 | 입력한 숫자 이하 짝수만 출력하기(승민) | 승민 | 2016.03.12 | 1432 |
318 | 제어문 연습(완성) | 선우 | 2016.03.12 | 116 |
317 | 짝수 홀수 갯수구하기(승민) | 승민 | 2016.03.12 | 1202 |
316 | for문 입력한숫자만큼 입력받고 평균구하기(승민) | 승민 | 2016.03.19 | 4447 |
315 | 반복제어문3 형성평가 1 | 선우 | 2016.03.19 | 285 |
314 | 반복제어문3 형성평가 2 | 선우 | 2016.03.19 | 303 |
313 | 반복제어문3 형성평가 3 | 선우 | 2016.03.19 | 212 |
312 | 반복제어문3 형성평가 4 | 선우 | 2016.03.19 | 301 |
311 | 반복제어문3 형성평가 5 | 선우 | 2016.03.19 | 351 |