PAT (Basic Level) Practice 1002 写出这个数 分数 20

读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。

输入格式:

每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。

输出格式:

在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。

输入样例:

1234567890987654321123456789
 

输出样例:

yi san wu
 
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
 
复制代码
解题:
#include<stdio.h>
#include<string.h>
int main()
{
char str[101];
char strsum[4];
char pinying[5] = {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};//数组储存拼音;
int sum=0;
int i;
int t=0;
gets(str);//用字符串接收,防止用整型接受会超出最大范围;
for(i=0;i<strlen(str);i++)
sum = sum + str[i] - 48;//字符转整型ASCII码;
while(sum>0)
{
strsum[t]=sum%10;//一位一位输出;
sum = sum/10;
t++;
}
printf("%s",pinying[strsum[t-1]]);//用下标查找转化成拼音
for(i=t-2;i>=0;i--)
{
printf(" %s",pinying[strsum[i]]);
}

}
复制代码

 

 

 

总结:

谨防数组超过范围,所以使用字符串。
posted @   slowlydance2me  阅读(36)  评论(2编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
点击右上角即可分享
微信分享提示