PAT 乙级 真题 1002. 写出这个数
2016-03-17 19:34
309 查看
1002.写出这个数
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
解题思路
简单题,直接读入求和即可,有个小技巧,在输入的时候可以用scanf("%nd",x)其中n为数字的位数,这个题如果直接一位一位的输入的话就可以不需要字符串的转换。
#include <cstdio> int main(){ char shuzi[10][20]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"}; int n,x=0; while(~scanf("%1d",&n)){ x+=n; }. //因为题目中的数据范围不大,所以只考虑到答案为三位数就可以通过了. if(x>99) printf("%s %s %s",shuzi[x/100],shuzi[(x%100-x%10)/10],shuzi[x%10]); else if(x>9) printf("%s %s",shuzi[x/10],shuzi[x%10]); else printf("%s",shuzi[x%10]); return 0; }
相关文章推荐
- libdvbpsi源码分析(四)PAT表解析/重建
- PAT配置
- 什么是端口复用动态地址转换(PAT) 介绍配置实例
- MikroTik layer7-protocol
- PAT是如何工作的
- PAT 乙级题:1002. 写出这个数 (20)
- PAT (Advanced Level) Practise 1001-1010
- 数据结构学习与实验指导(一)
- PAT Basic Level 1001-1010解题报告
- 1001. 害死人不偿命的(3n+1)猜想
- 1002. 写出这个数
- 1032. 挖掘机技术哪家强
- 1001. 害死人不偿命的(3n+1)猜想 (PAT basic)
- 1002. 写出这个数(PAT Basic)
- 1004. 成绩排名(PAT Basic)
- 1006. 换个格式输出整数(PAT Basic)
- 1007. 素数对猜想(PAT Basic)
- 1008. 数组元素循环右移问题
- 1009. 说反话(PAT Basic)
- 1011. A+B和C(PAT Basic)