题解 | #学英语#

学英语

http://www.nowcoder.com/practice/1364723563ab43c99f3d38b5abef83bc

题意

编写程序将一串阿拉伯数字转化为符合英语语法的写法,n2000000n≤2000000

解答

依据题目说明,我们可以发现数字在英语读法中三位数字看成一整体,后面再加一个计数单位。而相同部分的英语读法相同,由此我们可以想到利用递归将大数字分为几个三位的数字,再拼接在一起即可。

#include<bits/stdc++.h>
using namespace std;
int n;
string a[] = {"a0", "one", "two", "three", "four", "five", "six", "seven","eight", "nine", "ten", "eleven", "twelve", "thirteen", "fourteen", "fifteen", "sixteen", "seventeen", "eighteen", "ninteen"};//20以内的单词表
string b[] = {"b0", "b1", "twenty", "thirty", "forty", "fifty", "sixty","seventy", "eighty", "ninety"};//整十单词表
const string hun="hundred";
const string tho="thousand";
const string mil="million";
const string bil="billion";//连接词表
string engn(int n);
signed main() {
    while(~scanf("%d",&n)) {
        string ans=engn(n);
        cout << ans << endl;
    }
    return 0;
}
string engn(int n){
    if(n<20)
        return a[n];//若n小于20直接从表中输出
    else 
        if(n<100) 
        {
        if(n%10 == 0)//若n能被10整除
            return b[n/10];//从整十表中输出
        else
            return b[n/10]+" "+engn(n%10);//分别计算十位和个位
        }
    else 
        if(n<1000) 
        {
        if(n%100 == 0)
            return a[n/100]+" "+hun;//同理,若整百直接输出数字加百
        else
            return engn(n/100)+" "+hun+" and "+engn(n%100);//分别计算百位,十位和个位
        }
    else 
        if(n<1000000) //对于一百万以下的数字同理处理
        {
        if(n%1000 == 0)
            return engn(n/1000)+" "+tho;
        else
            return engn(n/1000)+" "+tho+" "+engn(n%1000);
        }
    else 
        {
        if(n%1000000==0)
            return engn(n/1000000)+" "+mil;
        else
            return engn(n/1000000)/*百万位上*/+" "+mil+" "+engn(n/1000%1000)/*百万位到千位*/+" "+tho+" "+engn(n%1000);/*千位到个位*/
        }
    return "err";
}

alt

一个数字递归的例子

时间复杂度:O(logn)O(logn),只需递归O(logn)O(logn)次。

空间复杂度:O(logn)O(logn),递归调用栈所用空间。

全部评论
ninteen -> nineteen,严谨
点赞 回复 分享
发布于 2023-03-24 01:09 辽宁

相关推荐

求offer的大角牛:不吃香菜
点赞 评论 收藏
分享
浪漫主义的虹夏:都是校友,还是同届,我就说直白点,不委婉了,我相信你应该也不是个玻璃心,首先你觉得一个双非的绩点写简历上有用吗?班长职务有用吗?ccf有用吗?企业会关心你高数满分与否吗?第二,第一个项目实在太烂,一眼就能看出是外卖,还是毫无包装的外卖,使用JWT来鉴权,把热点数据放进Redis这两个点居然还能写进简历里,说难听点这两个东西都是学个几十分钟,调用个API就能完成的事情,在双非一本的条件下,这种项目你觉得能拿出手吗,第二个项目你写的东西和你的求职方向有任何的匹配吗?第三,计设那一块毫无价值,如果想突出自己会前端,直接写入专业技能不行吗,最后,专业技能里像深入理解JVM底层原理这种你觉得这句话你自己真的能匹配吗?都是校友加上同届,我措辞直接,但希望能点出你的问题,想进大厂还得继续沉淀项目和学习
点赞 评论 收藏
分享
评论
4
1
分享

创作者周榜

更多
牛客网
牛客企业服务