1005 Spell It Right (20分)
Given a non-negative integer N, your task is to compute the sum of all the digits of N, and output every digit of the sum in English.
Input Specification:
Each input file contains one test case. Each case occupies one line which contains an N (≤10100).
Output Specification:
For each test case, output in one line the digits of the sum in English words. There must be one space between two consecutive words, but no extra space at the end of a line.
Sample Input:
12345
Sample Output:
one five
——刷pat也是非常煎熬了,今天第一道题能运用前几天学到的知识,自己写出来也是灰常开森了(虽然这个题目超级简单,哈哈哈)
一、试题分析:
- 输入数据为非负整数N (≤10100):不可使用int存储输入的数据,在这里我是使用的string类型来存储
- 如何获取N的每一位来sum求和:循环遍历str,使用str[i]下标提取即可(所提取的只是字符类型)
- 如何将字符类型转化为数字:str[i] - '0'
- 如何将最后的sum和用英文单词输出:
- 先将数字转化为字符串(to_string(sum) ——#include<string>);
- 再用数组string num[]存储英文单词即可
#include <iostream>
#include <string>
using namespace std;
int main()
{
string str;
string strnew;
string num[11]={"zero","one","two","three","four","five","six","seven","eight","nine","ten"}; //数组存储英文单词
int sum=0;
cin>>str;
for(int i=0;i<str.size();i++){
sum+=(str[i]-'0'); //字符转化为数字
}
strnew=to_string(sum); //数据转化为字符串
for(int i=0;i<strnew.size();i++){
if(i==0)
cout<<num[strnew[i]-'0'];
else
cout<<' '<<num[strnew[i]-'0'];
}
return 0;
}