/*1002 写出这个数 (20)(20 分)
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。

输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10^100^。

输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。

输入样例:

1234567890987654321123456789
输出样例:

yi san wu

*/

#include<stdio.h>
#include<math.h>
#include<string.h>

int main(void)
{
	int sum=0,len=1,i=1,t[100];
	char p[1000000],q;
	
	gets(p);
	for(int i=0;i<strlen(p);i++)
		sum+=(p[i]-48);

	while(sum/(int)(pow(10.0,(double)i))!=0)
	{
		i++;
		len=i;
	}
	
	for(int i=0;i<len;i++)
		t[i]=(sum/(int)(pow(10.0,(double)(len-i-1))))%10;
	
	for(int i=0;i<(len-1);i++)
	{
		switch(t[i])
		{
			case 1:
				printf("yi ");
				break;
			case 2:
				printf("er ");
				break;
			case 3:
				printf("san ");
				break;
			case 4:
				printf("si ");
				break;
			case 5:
				printf("wu ");
				break;
			case 6:
				printf("liu ");
				break;
			case 7:
				printf("qi ");
				break;
			case 8:
				printf("ba ");
				break;
			case 9:
				printf("jiu ");
				break;
			case 0:
				printf("ling ");
				break;
		}
	}
	switch(t[len-1])
		{
			case 1:
				printf("yi");
				break;
			case 2:
				printf("er");
				break;
			case 3:
				printf("san");
				break;
			case 4:
				printf("si");
				break;
			case 5:
				printf("wu");
				break;
			case 6:
				printf("liu");
				break;
			case 7:
				printf("qi");
				break;
			case 8:
				printf("ba");
				break;
			case 9:
				printf("jiu");
				break;
			case 0:
				printf("ling");
				break;
		}

	return 0;
}