PTA1002 写出这个数 (20 分)
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中
}
几点思考:
可以把相应的格式字符串存储到字符数组中,char b【10】【5】中的5代表最大长度(10行5列)
本题的精华所在,之前的做法都是想着判断所得到的数是几位数,再如何把每位上的数字存下来,所以用了for循环判断,而c++的库函数sprintf_s()提供了这个功能,不过有以下注意点(感谢评论大佬!!!):
- 带“_s”后缀的函数一般是为了让原版函数更安全,编译器(如VS)提供了sprintf_s()的话,不会出现编译错误,而PAT应该是没有提供的,所以需要去掉“_s”后缀。
- 但是在vs里反而是sprintf不让用,一定要你用sprintf_s
可用%s直接输出字符数组中的所有字符
PTA1002 写出这个数 (20 分)的更多相关文章
- PAT Basic 1002 写出这个数 (20 分)
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式: 每个测试输入包含 1 个测试用例,即给出自然数 n 的值.这里保证 n 小于 1. 输出格式: 在一行内输出 n 的 ...
- 1002 写出这个数 (20 分) java解题
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式: 每个测试输入包含 1 个测试用例,即给出自然数 n 的值.这里保证 n 小于 10^100. 输出格式: 在一行内输 ...
- PAT-字符串处理-B 1002 写出这个数 (20分)
题目: 思路: 先用字符串数组存储输入数字,然后依据num[i]-'0'对输入数字求和.然后对求和后的数字,进行分割,存储到数组中,然后遍历数组,依据存储汉语拼音的字符串二维数组进行输出 注意点: 注 ...
- PAT 1002 写出这个数 (20)(代码)
1002 写出这个数 (20)(20 分) 读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值.这里保证n小于10^100 ...
- PAT乙级 1002. 写出这个数 (20)
1002. 写出这个数 (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 读入一个自然数n,计算其各位数字 ...
- PAT-乙级-1002. 写出这个数 (20)
1002. 写出这个数 (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 读入一个自然数n,计算其各位数字 ...
- [C++]PAT乙级1002.写出这个数(20/20)
/* 1002. 写出这个数 (20) 读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值.这里保证n小于10^100. ...
- 【PAT】1002. 写出这个数 (20)
1002. 写出这个数 (20) 读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值.这里保证n小于10100. 输出格式 ...
- PAT 乙级练习题1002. 写出这个数 (20)
1002. 写出这个数 (20) 读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值.这里保证n小于10100. 输出格式 ...
- PAT 1002. 写出这个数 (20)
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值.这里保证n小于10100. 输出格式:在一行内输出n的各位数字之和的每 ...
随机推荐
- java中取整数绝对值_Java之——位运算求整数绝对值通过下面的位运算可以得到一个整数的绝对值
public int abs( int a ) {return (a + (a >> 31)) ^ (a >> 31) ;//前半部分-1或+0,后半部分取反 } a为正数的情 ...
- VM安装linux2022、设置root密码、设置国内更新源
一.创建虚拟机 1.打开VM软件选择"创建新的虚拟机" 2.选择"典型"即可 3.选择"稍后安装操作系统" 4.选择客户机操作系统为&quo ...
- 百题计划-1 codeforces1181C Flag 暴力模拟
https://codeforces.com/contest/1181/problem/C 题意:给一个n*m的格子(n,m<=1000),每个格子有个颜色,求可以条纹子矩阵的数量. 条纹矩阵就 ...
- Outlook网页版怎么设置自动回复?节假日怎么设置邮件自动回复?
在页面顶部,选择 设置> 查看所有 Outlook 设置 选择邮件>撰写和答复. 在答复或全部答复下,选择当您从阅读窗格中答复时的默认响应: 答复: 您的答复仅发送给发件人. 全部答复: ...
- 为什么要有jvm,jvm的作用?
jvm的两个作用:第一.运行并管理java源码文件所生成的Class文件.第二.在不同的操作系统上安装不同的jvm,从而去实现跨平台的一个保障. 一般情况下,即使不熟悉jvm的运行机制,也不影响业务代 ...
- anr查看的一种方法
看系统日志,系统日志里会看到system_server频繁进行GC,应该就是内存占用满了,然后看kernel log,会看到lowmemorykiller在频繁杀进程主要看RSS 搜utc,可以看到系 ...
- 解决 Outlook 的 Teams 会议加载项ID/链接等问题
参考: https://learn.microsoft.com/zh-cn/microsoftteams/troubleshoot/meetings/resolve-teams-meeting-add ...
- TP5 事务处理加锁
首先,数据库类型要是InnoDB,其次,加锁必须跟事务同时使用,还有,查询的时候都必须带锁,比如: db('sms')->lock(true)->where(['id'=>1])-& ...
- 获取异步请求的结果 | JS | VUEX | axios
这里都是获取异步axios的请求结果 一.async/await的方式(获取一个vuex中的异步请求的结果) 1.在vuex(store中的index.js)中定义异步函数 1> 在mutati ...
- pgsql 数据库密码登录配置
一.postgreSQL认证文件 pg_hba.conf 配置文件pg_hba.conf的位置,通常情况下的路径是 /etc/postgresql/[VERSION]/main/pg_hba.conf ...