PAT B1002 写出这个数

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

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

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

输入样例: 1234567890987654321123456789

输出样例: yi san wu

#include <stdio.h>
#include <algorithm>
#include <string>
#include <map>
#include <iostream>
#include <stack>
using namespace std;

int main(){
    map<int, string> mp;
    mp[1] = "yi";
    mp[2] = "er";
    mp[3] = "san";
    mp[4] = "si";
    mp[5] = "wu";
    mp[6] = "liu";
    mp[7] = "qi";
    mp[8] = "ba";
    mp[9] = "jiu";
    mp[0] = "ling";
    string s;
    cin >> s;
    int sum = 0;
    for (int i = 0; i < s.length(); i++){
        sum += int(s[i]-‘0‘);
    }
    stack<int> stk;
    while (sum != 0){
        int tmp = sum % 10;
        sum /= 10;
        stk.push(tmp);
    }
    while (!stk.empty()){
        int tmp = stk.top();
        stk.pop();
        if (stk.empty()){
            //printf("%s", mp[tmp]);
            cout << mp[tmp];
        }
        else{
            //printf("%s ", mp[tmp]);
            cout << mp[tmp]<<‘ ‘;
        }
    }
    //cout << endl<< mp[0];
    system("pause");
}

注意点:用了stack和map,其实根本不需要,储存0-9的拼音直接用一个string[10]就行了,因为刚好下标是对应的。而题目里10的100次方加和最大是9*100,不会超过3位数,因此也可以不用stack,直接一个int[3]就可以了,用vector也可以,遍历vector用vi.begin,vi.end。

原文地址:https://www.cnblogs.com/tccbj/p/10359141.html

时间: 2024-09-29 23:02:05

PAT B1002 写出这个数的相关文章

PAT 1002. 写出这个数

1002. 写出这个数 (20) 读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值.这里保证n小于10100. 输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1空格,但一行中最后一个拼音数字后没有空格. 输入样例: 1234567890987654321123456789 输出样例: yi san wu 1 #include<iostream> 2 #include<vector> 3 #

PAT 1002 写出这个数 (字符串)

题目>> 读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式: 每个测试输入包含 1 个测试用例,即给出自然数 n 的值.这里保证 n 小于 1. 输出格式: 在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格. 输入样例: 1234567890987654321123456789 输出样例: yi san wu 思路>> ①题目给出的n是小于10的100次方的,很明显不能用int型或者long lon

pat 1002. 写出这个数 (20)

读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值.这里保证n小于10100. 输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格. 输入样例: 1234567890987654321123456789 输出样例: yi san wu 1 #include <iostream> 2 #include <cstring> 3 using namespac

PAT——1002. 写出这个数

读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值.这里保证n小于10100. 输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格. 输入样例: 1234567890987654321123456789 输出样例: yi san wu package com.hone.basicalTry; import java.util.Scanner; public clas

【PAT】B1002 写出这个数 (20)(20 分)

#include<stdio.h> #include<stdlib.h> #include<string.h> int main() { char str[100],*p = str; gets(str); //scanf("%s", str); int num=0; while ((*p)!='\0') { num += (int)(*p)-48; p++; } sprintf(str, "%d", num); p = str;

B1002 写出这个数

#include<cstdio> #include<cstring> int main() { char str[100]; gets(str);//输入长度未知的字符串到字符数组的简洁办法 int sum=0; int len=strlen(str);//算长度时,最后一位'0'也算一位 for(int i=0;i<len;i++)//对所给一串数字的每一位求和 { sum+=str[i]-'0';//这个'0'不减是错的,还很关键 } int ans[10];//怎么确定

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

1002. 写出这个数 (20) 读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值.这里保证n小于10100. 输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格. 输入样例: 1234567890987654321123456789 输出样例: yi san wu C 代码如下: 1 #include <stdio.h> 2 #include <stdl

[PAT乙级] Practise 1002 写出这个数

PAT (Basic Level) Practice (中文)1002 1002 写出这个数 读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式: 每个测试输入包含 1 个测试用例,即给出自然数 n 的值.这里保证 n 小于 10100. 输出格式: 在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格. 输入样例: 1234567890987654321123456789 输出样例: yi san wu 思路: 先创

PAT (Basic Level) Practise 1002. 写出这个数

1002. 写出这个数 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值.这里保证n小于10100. 输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格. 输入样例: 1234567890987654321123456789 输出样