天梯赛练习集①——念数字两种解法

目录

一、题目                         

输入格式:

输出格式:

输入样例:

输出样例:

 二、解法

解法一:

解法二:


一、题目                         链接

输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出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的数字对应的读音储存到数组中。之后通过递归实现最先得到的数据最后输出

缺陷:用递归实现不好满足最后没有空格的要求,只是给大家提供思路。

猜你喜欢

转载自blog.csdn.net/whc18858/article/details/120889917