[L1 - 10分合集]念数字

L1-007 念数字 分数 10

作者 翁恺
单位 浙江大学

题目:

输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出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
代码长度限制																	16 KB
时间限制																		400 ms
内存限制																		64 MB

题解:

  • 代码一(推荐):先用二维字符数组存储字符串,将输入的数字保存为字符串形式,将第一个字符a[0]做特殊处理,如果是 ’ - ’ 就输出 " fu ", 不是就正常输出,接着用循环把剩余的字符全部打印。

    :a[0] - ‘0’ 运算会自动转型为int整形,因为字符本质上是ASCII码。

  • 代码二:将负数特殊处理后,将正整数带入递归,flag其实是结束的标志, 利用递归将数字一位一位切分,再一位一位输出。

  • 代码三(推荐):也可以用switch替换,本质是开关函数,来什么数字走哪扇门,比较简单。

代码一(数组定位):

#include <bits/stdc++.h>
using namespace std;

int main() {
	char a[1005], c[10][5] = {"ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu"};
	scanf("%s", a);
	printf("%s", a[0] == '-' ? "fu" : c[a[0] - '0']);
	for (int i = 1; i < strlen(a); i++) printf(" %s", c[a[i] - '0']);
	return 0;
}

代码二(递归):

#include <bits/stdc++.h>
using namespace std;

void print(int n, char a[10][5], int flag) {
	if (n > 9) print(n/10, a, flag);
	cout << a[n%10];
	if (n != flag) cout << " ";
}

int main() {
	int n;
	char a[10][5] = {"ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu"};
	cin >> n;
	if (n < 0) cout << "fu ";
	print(abs(n), a, abs(n));
	return 0;
} 

代码三(仿开关):

#include <bits/stdc++.h>
using namespace std;

int main() {
	char c;
	c = getchar();
	while(c != '\n') {
		if (c == '-') cout <<  "fu";
		if (c == '0') cout << "ling";
		if (c == '1') cout << "yi";
		if (c == '2') cout << "er";
		if (c == '3') cout << "san";
		if (c == '4') cout << "si";
		if (c == '5') cout << "wu";
		if (c == '6') cout << "liu";
		if (c == '7') cout << "qi";
		if (c == '8') cout << "ba";
		if (c == '9') cout << "jiu";
		c = getchar();
		if(c != '\n') cout << " ";
	}
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

bestkain233

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值