目录
一、题目 链接
输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出fu
字。十个数字对应的拼音如下:
0: ling
1: yi
2: er
3: san
4: si
5: wu
6: liu
7: qi
8: ba
9: jiu
输入格式:
输入在一行中给出一个整数,如:
1234
。
提示:整数包括负数、零和正数。
输出格式:
在一行中输出这个整数对应的拼音,每个数字的拼音之间用空格分开,行末没有最后的空格。如
yi er san si(无空格)
。
输入样例:
-600
结尾无空行
输出样例:
fu liu ling ling
结尾无空行
二、解法
解法一:
#include<stdio.h>
#include<string.h>
int main()
{
int flag = 0;
char* str[] = { "ling","yi","er","san","si","wu","liu","qi","ba","jiu" };
char ch[11] = { 0 };
scanf("%s", ch);
if (ch[0] == '-')
{
printf("fu ");
flag = 1;
}
for (int i = flag; i < strlen(ch); i++)//注意i的初始是0还是1
{
if (i < strlen(ch) - 1)
printf("%s ", str[ch[i] - '0']);
else
printf("%s\n", str[ch[i] - '0']);
}
return 0;
}
思路:将数据以char类型存储到数组中便于我们提取数据。
注意:只要注意为负数时要区分情况即可
解法二:
#include<stdio.h>
void print(int n, char* ch[11])
{
int i = n % 10;
n /= 10;
if (n > 0)
{
print(n , ch);
}
printf("%s ",ch[i]);
}
int main()
{
int n = 0;
char* ch[] = { "ling","yi","er","san","si","wu","liu","qi","ba","jiu","fu" };
scanf("%d", &n);
if (n < 0)
{
printf("%s ", ch[10]);
n = -n;
}
print(n, ch);
return 0;
}
思路:首先将0到9的数字对应的读音储存到数组中。之后通过递归实现最先得到的数据最后输出
缺陷:用递归实现不好满足最后没有空格的要求,只是给大家提供思路。