1002 写出这个数
题目
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10^100
输出格式
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
解析
先读入一个字符串,然后将每一位求和,注意读取的是字符而不是数,需要 - '0'用一个字符串数组保存要用到的所有字符,然后对和的每一位输出即可。
- 将每一位数求出来保存在一个数组中,遍历数组输出对应字符串
- 不保存每一位数,递归进入输出最高位依次往下,实际上递归会调用系统栈来保存
- 用C++ to_string()方法 或者 C sprintf() 将 int 转 string / char
答案
C(递归)
#include<stdio.h>
#include<string.h>
int b=0;
const char *a[11]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
int fun(int s){
if(s >= 1) fun(s / 10);
if(s != 0){
if(0 == b){
printf("%s",a[s%10]);
b ++;
}
else printf(" %s",a[s%10]);
}
}
int main(){
int sum = 0,n;
char s[100];
scanf("%s",s);
for(int i = 0;i < strlen(s);i ++){
sum += (s[i] - '0');
}
fun(sum);
}
C(sprintf())
#include<stdio.h>
#include<string.h>
int b = 0;
const char *a[11] = {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
int main(){
int sum = 0,n;
char s[100],re[4];
scanf("%s",s);
for(int i=0;i<strlen(s);i++){
sum += s[i] - '0';
}
sprintf(re,"%d",sum);
for(int i = 0 ; i < strlen(re) ; i ++){
if(i) printf(" %s",a[re[i] - '0']);
else printf("%s",a[re[i]- '0'] );
}
}
C++ (to_string())
#include<iostream>
#include<string>
#include<algorithm>
using namespace std;
string a[11] = {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
int main(){
int sum = 0;
string s;
cin >> s;
for(int i = 0 ; i < s.length() ; i ++){
sum += s[i] - '0';
}
s = to_string(sum);
for(int i = 0 ; i < s.length() ; i ++){
if(i) cout << " " << a[s[i] - '0'];
else cout << a[s[i] - '0'];
}
}

浙公网安备 33010602011771号