#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 |
509 | 회문 구하기 | killerjack | 2014.03.15 | 3193 |
508 | 화살표날아오기 플랫폼수하고 기차길이조정 | killerjack | 2014.02.08 | 1978 |
507 |
화살표 이동
![]() |
박윤택 | 2013.11.30 | 2415 |
506 |
화살표 응용
![]() |
박윤택 | 2013.11.30 | 1708 |
505 | 홀수면 n수까지 홀수 출력 짝수면 n수까지 짝수 출력(승민) | 승민 | 2016.08.20 | 465 |
504 | 홀수 짝수 for문(스민) | 승민 | 2016.03.05 | 555 |
503 | 핵맨 | 선우 | 2017.04.01 | 258 |
502 |
함수3-자가진단4
![]() |
박윤택 | 2014.08.15 | 589 |
501 | 함수2 자가진단7 | 선우 | 2016.07.09 | 162 |
500 | 함수(승민) | 승민 | 2016.08.06 | 118 |
499 | 함수(승민) | 승민 | 2016.06.04 | 135 |
498 | 함수 1 자가진단 8 | 선우 | 2016.06.18 | 136 |
497 | 포인트 | 승민 | 2016.09.10 | 203 |
496 | 테두리(승민) | 승민 | 2016.11.12 | 177 |
495 | 테두리(승민) | 승민 | 2016.11.12 | 158 |
494 | 큰수작은수 나머지수 출력하기(승민) | 승민 | 2016.08.06 | 247 |
493 | 크림빵, 새우깡, 콜라 돈만큼 구입하는 경우의 수 구하기 | killerjack | 2014.02.22 | 4434 |
492 | 최대공약수 최소공배수 | killerjack | 2014.02.15 | 4340 |
491 | 최대공약수 최대공배수 고친거 | killerjack | 2014.02.22 | 2538 |