回复: 16
跳转到指定楼层
上一主题 下一主题
收起左侧

优步电话面

全局:

2018(4-6月) 码农类General 硕士 全职@uber - 猎头 -   | | | 在职跳槽

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

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
上周五下班之前面的,头晕晕的,写的磕磕绊绊。。多谢小哥放我一
您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
使用VIP即刻解锁阅读权限或查看其他获取积分的方式
游客,您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
VIP即刻解锁阅读权限查看其他获取积分的方式
Unlock interview details and practice with AI
Curated Interview Questions from Top Companies
都可以早日找到称心的工作单位

评分

参与人数 4大米 +12 收起 理由
鬼雨澜蓝 + 3 谢谢楼主
mmbp123 + 3 给你点个赞!
天择 + 3 很有用的信息!
ouyangivan + 3 加油加油

查看全部评分


上一篇:Capital One phone interview
下一篇:脸书店面
推荐
天择 2018-5-22 02:46:32 | 只看该作者
全局:
  1.     static double cubicRoot(double n) {
  2.         
  3.         double start;
  4.         double end;
  5.         double err = 1e-12;
  6.         boolean isPositive;
  7.         double ans;
  8.         if (n > 0) {
  9.             isPositive = true;
  10.         } else {
  11.             isPositive = false;
  12.             n = -n;
  13.         }
  14.         
  15.         if (n >= 1) {
  16.             start = 1;
  17.             end = n;
  18.         } else {
  19.             start = n;
  20.             end = 1;
  21.         }
  22.         
  23.         while(true) {
  24.             double mid = (start + end)/2;
  25.             double error = Math.abs(mid*mid*mid - n);
  26.             System.out.println(mid);
  27.             if (error <= err) {
  28.                 ans = mid;
  29.                 break;
  30.             }
  31.             
  32.             if (mid*mid*mid > n) {
  33.                 end = mid;
  34.             } else {
  35.                 start = mid;
  36.             }   
  37.         }
  38.         return isPositive ?  ans : -ans;
  39.     }
复制代码

补充内容 (2018-5-22 02:47):
-1 到 1时 起点和终点反着来就行

评分

参与人数 2大米 +6 收起 理由
mrzhu + 3 很有用的信息!
love_ballon + 3 很有用的信息!

查看全部评分

回复

使用道具 举报

推荐
eason0218 2018-5-12 12:04:48 | 只看该作者
全局:
landy622 发表于 2018-5-12 05:02
牛顿 还是没办法handle 0.001

public static int sqrt(double x) {

可以handle没问题。测试过。
public static double cubicRoot(double x){
       double xn = 1.0;
       double eps = 1e-12;

       while (Math.abs(xn * xn * xn - x) > eps){
           xn = 2 * xn / 3 + x / (3 * xn * xn);
           System.out.println(xn);
       }
       return xn;
    }

以下是打印出来的convergence history:
0.6669999999999999
0.4454159172287918
0.2986240918149584
0.20282063977834344
0.1433169204928053
0.11177331656703804
0.10119656693666
0.10001409266436925
0.10000000198565878
0.10000000000000003
0.10000000000000003


没仔细看你的码,貌似你那个递推不太对。

评分

参与人数 2大米 +6 收起 理由
love_ballon + 3 很有用的信息!
mmbp123 + 3 给你点个赞!

查看全部评分

回复

使用道具 举报

推荐
 楼主| yabay91 2018-5-12 05:09:01 | 只看该作者
全局:
ouyangivan 发表于 2018-5-10 07:35
感谢楼主,不过这道题不用考虑(-1,1)之间就可以。二分法https://www.geeksforgeeks.org/find-cubic-root ...

来家电大米儿啊~~~~
回复

使用道具 举报

🔗
ouyangivan 2018-5-10 07:35:10 | 只看该作者
全局:
感谢楼主,不过这道题不用考虑(-1,1)之间就可以。二分法https://www.geeksforgeeks.org/find-cubic-root-of-a-number/
回复

使用道具 举报

🔗
 楼主| yabay91 2018-5-10 07:57:52 | 只看该作者
全局:
ouyangivan 发表于 2018-5-10 07:35
感谢楼主,不过这道题不用考虑(-1,1)之间就可以。二分法https://www.geeksforgeeks.org/find-cubic-root ...

要考虑的。比如0.001,按照你这个链接里面的解法,
一上来就是left =0, right = 0.001.
mid = 0.001/2=0.0005, mid**3 < 0.001, 然后left=mid=0.0005, right = 0.001
foobarfoobarfoo
一辈子也算不出来0.1
回复

使用道具 举报

🔗
ouyangivan 2018-5-11 20:56:51 | 只看该作者
全局:
yabay91 发表于 2018-5-10 07:57
要考虑的。比如0.001,按照你这个链接里面的解法,
一上来就是left =0, right = 0.001.
mid = 0.001/2=0 ...

在理啊。看到你强调了(-1,1)的情况,我都还没有去写一个在这个区间的test case实验一下。醉了醉了。
回复

使用道具 举报

🔗
landy622 2018-5-12 04:25:58 | 只看该作者
全局:
楼主能详细说说考虑 -1,1怎么处理吗
回复

使用道具 举报

🔗
 楼主| yabay91 2018-5-12 04:30:35 | 只看该作者
全局:
landy622 发表于 2018-5-12 04:25
楼主能详细说说考虑 -1,1怎么处理吗

比如-0.001,就先1 / -0.001 = -1000, 得出来等于-10,然后1/-10=-0.1
回复

使用道具 举报

🔗
eason0218 2018-5-12 04:36:48 | 只看该作者
全局:
牛顿法直接解决不行么..(-1, 1)之间也没问题。
回复

使用道具 举报

🔗
landy622 2018-5-12 05:02:32 | 只看该作者
全局:
eason0218 发表于 2018-5-12 04:36
牛顿法直接解决不行么..(-1, 1)之间也没问题。

牛顿 还是没办法handle 0.001

public static int sqrt(double x) {
        if (x == 0)
            return 0;
        double last = 0;
        double res = 1;
        while (res != last)
        {
            last = res;
            res = (res + x / res) / 3;
        }
        return (int)res;
    }
回复

使用道具 举报

🔗
 楼主| yabay91 2018-5-12 05:08:44 | 只看该作者
全局:
landy622 发表于 2018-5-12 05:02
牛顿 还是没办法handle 0.001

public static int sqrt(double x) {

来加点儿米啊小哥~~~~
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

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