聊聊跟三哥三姐面试和共事的经历

一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
E轮2.5亿美元融资
K12教育独角兽一起作业
北京-诚聘人工智能/教育/大数据岗
坐标湾区
Games Startup
招聘游戏开发工程师
游戏初创公司招聘工程师、UIUX Designer和游戏策划
码农求职神器Triplebyte:
不用海投
内推多家公司面试
把贵司招聘信息放这里
查看: 2319|回复: 5
收起左侧

[算法题] Groupon面试题

[复制链接] |试试Instant~ |关注本帖
Sendoh2015 发表于 2016-3-22 13:21:50 | 显示全部楼层 |阅读模式

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?Sign Up 注册获取更多干货

x
看到今天别人发的groupon的面经,有一道题是这样的,请问该怎么解?nt3acres.com/bbs
write a function
f(4) = four
f(14) = fourteen
f(123) = one hundred, twenty three
f(12345) = twelve thousand, three hundred, forty five

liuwujijay 发表于 2016-3-26 03:22:40 | 显示全部楼层
抛砖: 假设input 是 String input = “123456”。根据input.length()/3 的 结果来决定 当前单位是多少,如果input.length()/3 == 1 且input.length() % 3>0.则单位是千,然后百万,十亿。 先处理 input.length() % 3,然后三个 三个的 读。
回复 支持 反对

使用道具 举报

全球28万学生4.7分推荐
zdhzh05 发表于 2016-4-3 03:08:53 | 显示全部楼层
public class Solution {
        public String f(int n) {
                if (n == 0) return "zero";
                boolean pos = n > 0;
                long num = n;
                if (num < 0) num = -num;
                String[] a1 = new String[] {"", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "ten", "eleven", "twelve", "thirteen", "fourteen", "fifteen", "sixteen", "seventeen", "eighteen", "nineteen"};
                String[] a2 = new String[] {"", "", "twenty", "thirty", "fourty", "fifty", "sixty", "seventy", "eighty", "ninety"};
                String[] base = new String[] {"", "thousand", "million", "billion"};
                int b = 0;
                int d = 1;
                while (num/d >= 1000) {
                        b++;
                        d *= 1000;
                }
                StringBuilder sb = new StringBuilder();
                while (b >= 0) {
                        int v = (int)(num/d);
                        if (v >= 100) {
                                sb.append(a1[v/100]+" hundred ");
                                v %= 100;
                        }
                        if (v < 20) {
                                sb.append(a1[v]);
                        } else {
                                sb.append(a2[v/10]+" "+a1[v%10]);
                        }
                        sb.append(" "+base[b]+" ");
                        b--;
                        num %= d;
                        d /= 1000;
                }
                String ret = sb.toString().trim();
                return pos ? ret : "minus "+ret;
        }
}

Test:

4 four
14 fourteen
123 one hundred twenty three
12345 twelve thousand three hundred fourty five
1000 one thousand
100 one hundred
10 ten
1 one
0 zero
2147483647 two billion one hundred fourty seven million four hundred eighty three thousand six hundred fourty seven
-2147483648 minus two billion one hundred fourty seven million four hundred eighty three thousand six hundred fourty eight
回复 支持 反对

使用道具 举报

alpher 发表于 2016-4-3 07:02:28 | 显示全部楼层
Leet Code 273. Integer to English Words
回复 支持 反对

使用道具 举报

 楼主| Sendoh2015 发表于 2016-4-4 02:27:45 | 显示全部楼层
多谢啊,看来还是刷题不够啊
回复 支持 反对

使用道具 举报

Chilu_Tsao 发表于 2018-2-25 07:42:41 | 显示全部楼层
楼主你好,YouTube上有个大神讲解LeetCode的题目的,这里是这道题的视频链接:https://www.youtube.com/watch?v=RwFQvF0xx_k&list=PLvyIyKZVcfAmc54SmSOw0E6Y6L9oReTeb&index=23
回复 支持 反对

使用道具 举报

本版积分规则

提醒:发帖可以选择内容隐藏,部分板块支持匿名发帖。请认真读完以下全部说明:

■隐藏内容方法: [hide=200]你想要隐藏的内容比如面经[/hide]
■意思是:用户积分低于200则看不到被隐藏的内容
■可以自行设置积分值,不建议太高(200以上太多人看不到),也不建议太低(那就没必要隐藏了)
■建议只隐藏关键内容,比如具体的面试题目、涉及隐私的信息,大部分内容没必要隐藏。
■微信/QQ/电子邮件等,为防止将来被骚扰甚至人肉,以论坛私信方式发给对方最安全。
■匿名发帖的板块和方法:http://www.1point3acres.com/bbs/thread-405991-1-1.html

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明

custom counter

GMT+8, 2018-5-22 03:00

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

快速回复 返回顶部 返回列表