zoj 1858 Soundex

/*
	一些字母被标号,还有一些没被标号,不用处理;找到单词的数字表示法
	若连续的字母属于同一类,输出一个数字
*/
#include<stdio.h>
char s[30];
int ha(char *p)
{
	if(*p=='A'||*p=='E'||*p=='I'||*p=='O'||*p=='U'||*p=='H'||*p=='W'||*p=='Y')
		return 0;
	else if(*p=='B'||*p=='F'||*p=='P'||*p=='V')
		return 1;
	else if(*p=='C'||*p=='G'||*p=='J'||*p=='K'||*p=='Q'||*p=='S'||*p=='X'||*p=='Z')
		return 2;
	else if(*p=='D'||*p=='T')
		return 3;
	else if(*p=='L')
		return 4;
	else if(*p=='M'||*p=='N')
		return 5;
	else if(*p=='R')
		return 6;
}
int main()
{
	while(gets(s))
	{
		int i,j,k=7;;
		for(i=0;s[i];i++)
		{
			j=ha(&s[i]);
			if(j)
			{
				if(k==j)
				{
					continue;
				}
				else
				{
					printf("%d",j);
					k=j;
				}
			}
			else
			{
				k=j;
			}
		}
		printf("\n");
	}
	return 0;
}

你可能感兴趣的:(zoj 1858 Soundex)