题目如下:

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

输入格式:

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

输出格式:

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

输入样例:

                                                                             1234567890987654321123456789
 

输出样例:

                                                                                       yi san wu
一开始我还没意识到10的100次方是个什么概念,然后去搜了一下:世界上所有的沙漠的沙子数目约等于10^100
所以用int、double、long类型去接收是不可能的。只能用char类型或者string,这里用string类型(记得include<string>)
1    string nums;
2 cin >> nums;
3 for(int i = 0;i < nums.size();++i)
4 {
5 int num = nums[i] - '0';
6 sum += num;
7 }

这是main函数中接收输入的代码,这时已经能得到输入的数据的各位之和了,我不想在main函数中写过多代码,所以接下来的判断这个sum是几位数的工作就交给另一个函数

在这个函数中要判断这个sum是几位数,再对应的去输出这个数对应的拼音。

 1 void fun(int sum)
2 {
3 vector<int> sums;
4 int a,b,c,d,e;
5 if(sum/10000 >= 1)
6 {//超过5位数 包括5位数
7 e = sum/10000;
8 d = (sum-e*10000)/1000;
9 c = (sum-e*10000-d*1000)/100;
10 b = (sum-e*10000-d*1000-c*100)/10;
11 a = (sum-e*10000-d*1000-c*100 -b*10);
12 sums.push_back(e);
13 sums.push_back(d);
14 sums.push_back(c);
15 sums.push_back(b);
16 sums.push_back(a);
17 }else if(sum/1000 >= 1)
18 {//4位数
19 d = sum/1000;
20 c = (sum-d*1000)/100;
21 b = (sum-d*1000-c*100)/10;
22 a = (sum-d*1000-c*100 -b*10);
23 sums.push_back(d);
24 sums.push_back(c);
25 sums.push_back(b);
26 sums.push_back(a);
27 }else if(sum/100 >= 1)
28 {//3位数
29 c = sum/100;
30 b = (sum-c*100)/10;
31 a = (sum-c*100 -b*10);
32 sums.push_back(c);
33 sums.push_back(b);
34 sums.push_back(a);
35 }else if(sum/10 >= 1)
36 {//2位数
37 b = sum/10;
38 a = (sum-b*10);
39 sums.push_back(b);
40 sums.push_back(a);
41 }else
42 {//1位数
43 a = sum;
44 sums.push_back(a);
45 }
46 }

这里重用了我之前的一段代码,这一大串看着非常多,其实一旦确定是几位数后就只执行if中的,所以时间不会很长。(但是代码冗余很多)

判断sum的位数以后,再用一个switch语句来输出即可。

 1     for(vector<int>::iterator it = sums.begin();it != sums.end();it++)
2 {
3 switch(*it)
4 {
5 case 1:cout << "yi" ; break;
6 case 2:cout << "er" ; break;
7 case 3:cout << "san" ; break;
8 case 4:cout << "si" ; break;
9 case 5:cout << "wu" ; break;
10 case 6:cout << "liu" ; break;
11 case 7:cout << "qi" ; break;
12 case 8:cout << "ba" ; break;
13 case 9:cout << "jiu" ; break;
14 case 0:cout << "ling" ; break;
15 }
16 if(it != sums.end()-1)
17 {
18 cout << " ";
19 }

最后在main函数中调用这个方法即可。

完整代码如下:

 1 #include <iostream>
2 #include <string>
3 #include <vector>
4 using namespace std;
5
6 void fun(int sum)
7 {
8 vector<int> sums;
9 int a,b,c,d,e;
10 if(sum/10000 >= 1)
11 {//超过5位数 包括5位数
12 e = sum/10000;
13 d = (sum-e*10000)/1000;
14 c = (sum-e*10000-d*1000)/100;
15 b = (sum-e*10000-d*1000-c*100)/10;
16 a = (sum-e*10000-d*1000-c*100 -b*10);
17 sums.push_back(e);
18 sums.push_back(d);
19 sums.push_back(c);
20 sums.push_back(b);
21 sums.push_back(a);
22 }else if(sum/1000 >= 1)
23 {//4位数
24 d = sum/1000;
25 c = (sum-d*1000)/100;
26 b = (sum-d*1000-c*100)/10;
27 a = (sum-d*1000-c*100 -b*10);
28 sums.push_back(d);
29 sums.push_back(c);
30 sums.push_back(b);
31 sums.push_back(a);
32 }else if(sum/100 >= 1)
33 {//3位数
34 c = sum/100;
35 b = (sum-c*100)/10;
36 a = (sum-c*100 -b*10);
37 sums.push_back(c);
38 sums.push_back(b);
39 sums.push_back(a);
40 }else if(sum/10 >= 1)
41 {//2位数
42 b = sum/10;
43 a = (sum-b*10);
44 sums.push_back(b);
45 sums.push_back(a);
46 }else
47 {//1位数
48 a = sum;
49 sums.push_back(a);
50 }
51 for(vector<int>::iterator it = sums.begin();it != sums.end();it++)
52 {
53 switch(*it)
54 {
55 case 1:cout << "yi" ; break;
56 case 2:cout << "er" ; break;
57 case 3:cout << "san" ; break;
58 case 4:cout << "si" ; break;
59 case 5:cout << "wu" ; break;
60 case 6:cout << "liu" ; break;
61 case 7:cout << "qi" ; break;
62 case 8:cout << "ba" ; break;
63 case 9:cout << "jiu" ; break;
64 case 0:cout << "ling" ; break;
65 }
66 if(it != sums.end()-1)
67 {
68 cout << " ";
69 }
70 }
71 }
72
73
74 int main()
75 {
76 int sum = 0;
77 string nums;
78 cin >> nums;
79 for(int i = 0;i < nums.size();++i)
80 {
81 int num = nums[i] - '0';
82 sum += num;
83 }
84 fun(sum);
85 return 0;
86 }
 

C++ 写出这个数的更多相关文章

  1. PAT乙级 1002. 写出这个数 (20)

    1002. 写出这个数 (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 读入一个自然数n,计算其各位数字 ...

  2. PAT-乙级-1002. 写出这个数 (20)

    1002. 写出这个数 (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 读入一个自然数n,计算其各位数字 ...

  3. [C++]PAT乙级1002.写出这个数(20/20)

    /* 1002. 写出这个数 (20) 读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值.这里保证n小于10^100. ...

  4. PAT 1002 写出这个数 (20)(代码)

    1002 写出这个数 (20)(20 分) 读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值.这里保证n小于10^100 ...

  5. PTA(Basic Level)-1002 写出这个数

    一 1002 写出这个数  读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式: 每个测试输入包含 1 个测试用例,即给出自然数 n 的值.这里保证 n 小于 10​10 ...

  6. 【PAT】1002. 写出这个数 (20)

    1002. 写出这个数 (20) 读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值.这里保证n小于10100. 输出格式 ...

  7. PAT1002 写出这个数 (C++实现)

    PAT乙级考试题目 1002 写出这个数 (20 分) 题目要求: 读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式: 每个测试输入包含 1 个测试用例,即给出自然数  ...

  8. 【算法笔记】B1002 写出这个数

    1002 写出这个数 (20 分)读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式:每个测试输入包含 1 个测试用例,即给出自然数 n 的值.这里保证 n 小于 101 ...

  9. PAT 乙级 1002.写出这个数 C++/Java

    1002 写出这个数 (20 分) 题目来源 读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式: 每个测试输入包含 1 个测试用例,即给出自然数 n 的值.这里保证 n ...

  10. PAT 乙级练习题1002. 写出这个数 (20)

    1002. 写出这个数 (20) 读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值.这里保证n小于10100. 输出格式 ...

随机推荐

  1. SpringCloud微服务实战——搭建企业级开发框架(十二):OpenFeign+Ribbon实现负载均衡

      Ribbon是Netflix下的负载均衡项目,它主要实现中间层应用程序的负载均衡.为Ribbon配置服务提供者地址列表后,Ribbon就会基于某种负载均衡算法,自动帮助服务调用者去请求.Ribbo ...

  2. ssl 原理和建立连接过程

    ssl ("Secure Sockets Layer")加密原理 和https的关系https = http + ssl ssl 位置: SSL握手 证书主要作用是在SSL握手中, ...

  3. topk算法

    方法一 堆排序 自建堆 heapMax方法,从上至下调整堆 pop时,可以使用自上而下调整堆,调用heapMax(arr,0,sz-1); push时,需要自下到上调整即 从上到下调整: void h ...

  4. Maven 问题 Failure to transfer org.apache.maven.plugins:maven-surefire-plugin:pom:3.0.0-M1 的处理

    一.问题描述 Maven项目报错,该项目是导入的项目,然后再通过开发工具打开项目时,pom.xml文件报错. 并且新建Maven Project 也会报错. 二.报错详细Failure to tran ...

  5. 访问kubernetes CRD的几种方式

    访问kubernetes CRD的几种方式 最近在使用代码操作VictoriaMetrics Operator的CRD资源的过程中,探究了集中访问CRD资源的方式.下面以VictoriaMetrics ...

  6. 使用Abp vnext构建基于Duende.IdentityServer的统一授权中心(一)

    原来看到很多示例都是基于IdentityServer4的统一授权中心,但是IdentityServer4维护到2022年就不再进行更新维护了,所以我选择了它的升级版Duende.IdentitySer ...

  7. [python]Robotframework+Git+jenkins实现持续集成并生成测试报告发送邮件

    1.环境需求 &robotframework(不写搭建,自行百度) & git(不写安装,自行百度) &jenkins 2.安装jenkins 官网下载最新版本https:// ...

  8. C#简单配置类及数据绑定

    目录 简介 配置基类 派生配置类 数据绑定 Winform中的数据绑定 WPF下的数据绑定 附件 简介 本文实现一个简单的配置类,原理比较简单,适用于一些小型项目.主要实现以下功能: 保存配置到jso ...

  9. 前端---梳理 http 知识体系 2

    为什么要有HTTPS HTTP 天生具有明文的特点,整个传输过程完全透明,任何人都能够在链路中截获.修改或者伪造请求 / 响应报文,数据不具有安全性.仅凭HTTP 自身是无法解决的,需要引入新的HTT ...

  10. page_fault_in_nonpaged_area异常解决方案(已解决)

    电脑在运行虚拟机的时候异常重启,多次打开结果一样,问了客服告诉我导致蓝屏的原因很多,可能是驱动不兼容,系统,或其他.{没点有用的} 百度到这个方案: 打开->此电脑->右键属性->高 ...