zoukankan      html  css  js  c++  java
  • 1002 写出这个数 (20 分)

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

    输入格式:

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

    输出格式:

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

    输入样例:

    1234567890987654321123456789
    

    输出样例:

    yi san wu


    #include"iostream"
    #include <sstream>
    using namespace std;
    int main()
    {
        string c;
        cin>>c;
        int sum=0;
        for(int i=0;i<(signed)c.length();i++)
        {
            sum+=c[i]-'0';
        }
    
        string str;
        stringstream ss;
        ss<<sum;
        ss>>str;
        int i=0;
        for(i=0;i<(signed)str.length()-1;i++)
        {
            switch(str[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<<"shi"<<' ';break;
                default:break;
            }
        }
            switch(str[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<<"shi";break;
                default:break;
            }
    
    }

    这道题没有完全正确,第一段有错误,但是完全找不到在哪,如果有人碰巧看见可以帮我找一下。。

    原来是0写成shi了。。太粗心了呜呜呜,希望大家引以为鉴!!改正之后完全正确了

    其中遇到了警告,我以为是错误,就找了一下:A warning:comparison between signed and unsigned integer expressions [-Wsign-compare]

    原因:

    有符号和无符号比较 --> 修改:强制转换类型

    在网上搜答案的时候看到一段非常简洁优美的代码:

    #include <iostream>
    #include <string>
    using namespace std;
    int main() {
        string s;
        cin >> s;
        int sum = 0;
        string str[10] =  {"ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu"};
        for (int i = 0; i < s.length(); i++)
            sum += (s[i] - '0');
        string num = to_string(sum);
        for (int i = 0; i < num.length(); i++) {
            if (i != 0) cout << " ";
            cout << str[num[i] - '0'];
        }
        return 0;
    }
  • 相关阅读:
    BeautifulSoup的高级应用 之.parent .parents .next_sibling.previous_sibling.next_siblings.previous_siblings
    zoj 1655 单源最短路 改为比例+最长路
    localstorage
    unix中文件I/O
    TextView超链接
    Linux环境安装phpredis扩展
    可替代google的各种搜索引擎
    otto源代码分析
    8天学通MongoDB——第二天 细说增删查改
    MongoDB (十一) MongoDB 排序文档
  • 原文地址:https://www.cnblogs.com/ygjojo/p/10100062.html
Copyright © 2011-2022 走看看