【PAT甲级真题】- Spell It Right(20)

题目来源

Spell It Right

题目描述点击链接自行查看

注意点:

  • 末尾无空格,多换一行

Description

Given a non-negative integer N N N, your task is to compute the sum of all the digits of N N 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 ( ≤ 10 100 ) N (≤10 ^{100}) 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

题目大意

给出一个很大的整数 N N N ,计算它每个位的数字之和,然后从左到右,输出这个和的每个位的数字对应的英文

思路简介

一道打表题

对于数字转字母的处理就用一个字符串数组打表

cpp 复制代码
string dig[]={
    "zero","one","two","three",
    "four","five","six","seven",
    "eight","nine"
};

输入记得输字符串,整数无法直接输入,10\^{100} 超出范围了

求和时,数字字符减去 '0' 即为其数字的数值

求和后对照表输出即可

遇到的问题

  1. 无,一遍过

代码

cpp 复制代码
/**
 * https://pintia.cn/problem-sets/994805342720868352/exam/problems/type/7?problemSetProblemId=994805519074574336
 * 打表
 */
#include<bits/stdc++.h>
using namespace std;

string dig[]={
    "zero","one","two","three",
    "four","five","six","seven",
    "eight","nine"
};

void solve(){
    string n;cin>>n;   
    int sum=0;
    for(auto x:n){
        sum+=x-'0';
    }
    string res=to_string(sum);
    int len=res.size();
    for(int i=0;i<len;++i){
        cout<<dig[res[i]-'0'];
        if(i!=len-1)cout<<' ';
    }
    cout<<'\n';
}

int main(){
    ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
    //fstream in("in.txt",ios::in);cin.rdbuf(in.rdbuf());
    int T=1;
    //cin>>T;
    while(T--){
        solve();
    }
    return 0;
}
相关推荐
搬砖魁首1 小时前
基础能力系列 - 多线程2 - 条件变量
c++·rust·条件变量·原子类型·线程同步互斥
chase_my_dream1 小时前
C++ + SLAM 高频面试问题整理
开发语言·c++·面试
牛油果子哥q2 小时前
【C++ STL string 】C++ STL string 终极精讲:底层原理、内存机制、全套API、深浅拷贝、易错坑点与工程实战规范
数据库·c++
凡人叶枫3 小时前
Effective C++ 条款04:确定对象被使用前已先被初始化
java·linux·开发语言·c++·嵌入式开发
不想写代码的星星4 小时前
std::move 根本不移动,就像老婆饼里没有老婆
c++
redaijufeng4 小时前
C++雾中风景7:闭包
c++·算法·风景
小欣加油4 小时前
leetcode287寻找重复数
数据结构·c++·算法·leetcode
思麟呀4 小时前
C++11 核心特性(三):强类型枚举、static_assert 与 std::tuple
开发语言·c++
一拳一个呆瓜5 小时前
【STL】C++程序的启动与终止
c++·stl
凡人叶枫5 小时前
Effective C++ 条款07:为多态基类声明 virtual 析构函数
linux·c语言·开发语言·c++