조회 수 989 추천 수 0 댓글 0

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



List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 글쓰기는 하루 5개, 댓글은 10개만 가능합니다. 좋은아빠되기 2019.02.15 322
공지 키보드 화살표값 출력 좋은아빠되기 2016.11.19 1101
공지 원하는 좌표에 값 출력하기 좋은아빠되기 2016.11.19 2413
공지 Python(파이썬) 학습 자료 PDF 1 file 좋은아빠되기 2014.12.10 10370
공지 dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) 좋은아빠되기 2014.06.07 4733
공지 DEV-C++ 기본 코드 좋은아빠되기 2013.06.19 8318
공지 무료 C++ 컴파일러(윈도우용) DEV-C++ 좋은아빠되기 2013.06.18 18978
공지 이클립스 C++ 설치 파일들 좋은아빠되기 2013.06.18 37878
130 정올 배열1 형성평가4 정승준 2018.09.08 163
129 정올 - 실력키우기 - 2진수를 10진수로(문자열로 입력) 조정미 2017.12.02 163
128 주사위(승민) 승민 2016.08.20 163
127 정올 반복제어문2 형성평가A 정승준 2018.01.27 159
126 정올 - 실전대비 - RESETO(1232) 조정미 2018.06.02 156
125 124 : 선택제어문 - 형성평가5 adbdcd123 2018.08.25 154
124 테두리(승민) 승민 2016.11.12 154
123 정올 - 문제은행 - 과자게임(1319) 조정미 2018.06.30 152
122 정올 - 실전대비 - PERKET(1127) 조정미 2018.06.02 152
121 대덕마고 승민 2016.10.29 152
120 for문 하나만 사용해서 일정수 몇번나오는지 구하는거(승민) 승민 2016.05.25 152
119 배열1 최소 최대 선우 2016.04.02 152
118 535 : 선택제어문 - 자가진단8 adbdcd123 2018.08.25 150
117 정올 문자마름모 조정미 2017.11.18 150
116 함수2 자가진단7 선우 2016.07.09 147
115 배열1 자가진단2 (승민) 승민 2016.04.02 147
114 정올 - 알고리즘 - 짚신벌레(1822) - 미완2 조정미 2018.03.03 146
113 정올 배열1 형성평가6 정승준 2018.09.15 143
112 정올 반복제어문3 자가진단4(반대) 정승준 2018.03.03 143
111 정올 반복제어문3 자가진단7 정승준 2018.03.03 141
Board Pagination Prev 1 ... 15 16 17 18 19 20 21 22 23 24 ... 26 Next
/ 26