#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)
조회 수 996 추천 수 0 댓글 0
번호 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|
공지 | 글쓰기는 하루 5개, 댓글은 10개만 가능합니다. | 좋은아빠되기 | 2019.02.15 | 467 |
공지 | 키보드 화살표값 출력 | 좋은아빠되기 | 2016.11.19 | 1227 |
공지 | 원하는 좌표에 값 출력하기 | 좋은아빠되기 | 2016.11.19 | 2540 |
공지 |
Python(파이썬) 학습 자료 PDF
1 ![]() |
좋은아빠되기 | 2014.12.10 | 10509 |
공지 | dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) | 좋은아빠되기 | 2014.06.07 | 4879 |
공지 | DEV-C++ 기본 코드 | 좋은아빠되기 | 2013.06.19 | 8463 |
공지 | 무료 C++ 컴파일러(윈도우용) DEV-C++ | 좋은아빠되기 | 2013.06.18 | 19109 |
공지 | 이클립스 C++ 설치 파일들 | 좋은아빠되기 | 2013.06.18 | 38028 |
210 | 영단어 입력한후 그단어중 가장큰 아스키코드 구하기(승민) | 승민 | 2016.04.02 | 516 |
209 | 배열1 자가진단5 | 선우 | 2016.04.02 | 243 |
208 | 띄어쓰기까지 프로그램 출력하기(승민) | 승민 | 2016.04.02 | 1920 |
207 | scanf함수를 사용한 문자열(승민) | 승민 | 2016.04.02 | 203 |
206 | scanf함수를 사용한 배열(승민) | 승민 | 2016.03.26 | 808 |
205 | 배열 5개숫자 더히가(승민) | 승민 | 2016.03.26 | 117 |
204 | 배열 3가지 | 선우 | 2016.03.19 | 109 |
203 | 숫자두개 입력하고 큰거 작은거 구분하고 작은숫자부터 큰숫자까지 곱하기(승민) | 승민 | 2016.03.19 | 231 |
202 | 반복제어문3 형성평가 7 | 선우 | 2016.03.19 | 229 |
201 | 반복제어문3 형성평가 6 | 선우 | 2016.03.19 | 219 |
200 | 반복제어문3 형성평가 5 | 선우 | 2016.03.19 | 349 |
199 | 반복제어문3 형성평가 4 | 선우 | 2016.03.19 | 297 |
198 | 반복제어문3 형성평가 3 | 선우 | 2016.03.19 | 203 |
197 | 반복제어문3 형성평가 2 | 선우 | 2016.03.19 | 300 |
196 | 반복제어문3 형성평가 1 | 선우 | 2016.03.19 | 278 |
195 | for문 입력한숫자만큼 입력받고 평균구하기(승민) | 승민 | 2016.03.19 | 4413 |
194 | 짝수 홀수 갯수구하기(승민) | 승민 | 2016.03.12 | 1198 |
193 | 제어문 연습(완성) | 선우 | 2016.03.12 | 106 |
192 | 입력한 숫자 이하 짝수만 출력하기(승민) | 승민 | 2016.03.12 | 1420 |
191 | 정올 반복제어문3 자가진단4 | 선우 | 2016.03.12 | 203 |