1002 写出这个数 (20 分)

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

输入格式:

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

输出格式:

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

输入样例:

1234567890987654321123456789

输出样例:

yi san wu

C算法实现:

#include<stdio.h>
int main(){
int sum=0,k=0,sum1,s[15];
char ch;
//每次读取一个数
ch = getchar();
while(ch!='\n'){
switch(ch){
case '1':sum=sum+1;break;
case '2':sum=sum+2;break;
case '3':sum=sum+3;break;
case '4':sum=sum+4;break;
case '5':sum=sum+5;break;
case '6':sum=sum+6;break;
case '7':sum=sum+7;break;
case '8':sum=sum+8;break;
case '9':sum=sum+9;break;
case '0':sum=sum+0;break;
}
ch = getchar();
}
//printf("%d",sum);
sum1=sum;
//判断是几位数
while(sum1){
sum1=sum1/10;
k++;
}
for(int i=k-1;i>=0;i--){
s[i]=sum%10;//分别求每位数
sum=sum/10;
} for(int i=0;i<k;i++){
switch(s[i]){
case 1:printf("yi");break;
case 2:printf("er");break;
case 3:printf("san");break;
case 4:printf("si");break;
case 5:printf("wu");break;
case 6:printf("liu");break;
case 7:printf("qi");break;
case 8:printf("ba");break;
case 9:printf("jiu");break;
case 0:printf("ling");break; }
if(i!=(k-1))
{printf(" ");}
else{
printf("\n");
} }
return 0;
}

思想:由于输入的数可达10的100次方,所以用数组存储不现实,因此可将数字作为字符输入,用getchar方法循环获取一个数,当获取到的字符为回车(‘\n’)时停止,再用switch进行判断,即可求出所有数之和,定义一个k来标记是几位数,再用数组存储每一位上的数字,最后对应字符串输出

算法二(一点点小改进,C++实现):

#include<bits/stdc++.h>//通用懒人写法,包含所有的库函数,由于本人还没来得及系统学习stl,也一般不会						//涉及到高级的库函数,所以就这么写了,建议还是系统学习stl
using namespace std;
int main(){
string n;
cin>>n;
int i=0,sum=0,sum1,k=0,s[10];
while(n[i]!='\0'){
sum=sum+(n[i]-'0');
i++;
}
//cout<<sum; sum1=sum;
//判断是几位数
while(sum1){
sum1=sum1/10;
k++;
}
for(int i=k-1;i>=0;i--){
s[i]=sum%10;//分别求每位数
sum=sum/10;
} for(int i=0;i<k;i++){
switch(s[i]){
case 1:cout<<"yi";break;
case 2:cout<<"er";break;
case 3:cout<<"san";break;
case 4:cout<<"si";break;
case 5:cout<<"wu";break;
case 6:cout<<"liu";break;
case 7:cout<<"qi";break;
case 8:cout<<"ba";break;
case 9:cout<<"jiu";break;
case 0:cout<<"ling";break; }
if(i!=(k-1))
{cout<<" ";}
else{
cout<<endl;
}
}
return 0;
}

思想:将要输入的变量定义为一个字符串,当输入的字符为‘\0’,也就是回车时,结束输入(‘\0’获取不到),所得的字符串可以直接作为数组使用,通过下标获取元素,当所得字符为数字时,可以用s[i]-'0'将数字字符转化为int类型的数字进行四则运算。

算法三(贴一个大佬的简洁代码,供参考学习)

#include <iostream>
using namespace std;
int main()
{
int sum = 0;
char ch, s[4]; //ch作为临时变量保存输入的每一个字符,s保存sum的每一个数字 ,因为题目小于1000
char b[10][5] = { "ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu" };
while ((ch = getchar()) != '\n') //如果一直输入字符,不按回车的话
sum += (ch - '0');
sprintf_s(s, "%d", sum); // sprintf(char *buffer, const char *format,[ argument])将任意类型数据按某种格式转换成字符串
for (int i = 0; s[i] != 0; i++) {
if (i > 0) //消除第一个空格
printf(" ");
printf("%s", b[s[i] - '0']);
}
return 0;//上文sprintf中s为s[4]数组名,将sum的值存放在s中
}

几点思考:

  1. 可以把相应的格式字符串存储到字符数组中,char b【10】【5】中的5代表最大长度(10行5列)

  2. 本题的精华所在,之前的做法都是想着判断所得到的数是几位数,再如何把每位上的数字存下来,所以用了for循环判断,而c++的库函数sprintf_s()提供了这个功能,不过有以下注意点(感谢评论大佬!!!):

    • 带“_s”后缀的函数一般是为了让原版函数更安全,编译器(如VS)提供了sprintf_s()的话,不会出现编译错误,而PAT应该是没有提供的,所以需要去掉“_s”后缀。
    • 但是在vs里反而是sprintf不让用,一定要你用sprintf_s
  3. 可用%s直接输出字符数组中的所有字符

最新文章

  1. C#中通过反射方法获取控件类型和名称
  2. .Net Core CLI在CentOS7的安装及使用简介
  3. python 进程间共享数据 (一)
  4. Google Map API key 获取方法
  5. SQL修改表结构之添加主键,添加IDENTITY属性
  6. ASP.NET MVC 4使用Bundle的打包压缩JS/CSS
  7. Windows 7 IIS HTTP 错误 500.21 – Internal Server Error 解决方法
  8. CSS 边框的宽度
  9. 系统性能优化分析—CPU消耗
  10. Free Mind » Blog Archive » Yakuake + dtach vs Screen + urxvt
  11. ftp服务器的搭建
  12. Python浅谈requests三方库
  13. 剑指offer数组1
  14. linux服务基础(二)之httpd2.2基础配置
  15. Linux 安装 Rabbit MQ
  16. Python学习笔记,day1
  17. Perl数组和hash相关函数
  18. Day12 Python基础之生成器、迭代器(高级函数)(十)
  19. C# Excel To DataTable
  20. 机器学习理论基础学习10--- 高斯混合模型GMM

热门文章

  1. C#消息泵探索(一)
  2. TCP通信实现两个主机之间的信息交互
  3. Typora以及Markdown学习
  4. 集群分发xsync xcall kafka启动脚本命令,命令方式安装epel源
  5. 自考网络原理:安全套接字层SSL
  6. k8s_使用k8s部署博客系统svc、secret、configmap(三)
  7. 小程序modal弹窗
  8. centos7 python2.7.5安装mysqldb
  9. docker 部署的mariadb数据库备份还原方案
  10. app对接微信支付(app支付)