📣 独立日限时特惠: VIP通行证立减$68
楼主: kklt92
跳转到指定楼层
上一主题 下一主题
收起左侧

google onsite 12/18 面经

🔗
毛线线 2018-12-23 06:19:39 | 只看该作者
全局:
hulahu 发表于 2015-12-22 09:24
楼主, fibonacci 和 fibonacci 怎么做啊

Greedy 就可以了。每次选最大的数。然后把原数减去你选的数,再重复。
回复

使用道具 举报

🔗
毛线线 2018-12-23 06:24:08 | 只看该作者
全局:
GatorAM 发表于 2015-12-31 07:23
楼主能详细说一下么?是不是假如有3个线程, 第一个线程产生所有括号序列并前三个是“()(”,第二个线 ...

把string切成2半。一个线程数第一半多了几个(,另一个线程数第二半少了几个(,如果一样的话就是true。
你也可以多分几个线程,切成n份。
回复

使用道具 举报

🔗
anywho 2018-12-31 09:08:57 | 只看该作者
全局:
斐波那契数列那题,可以很简单的用递归来做
  1. vector<int> findSeries(int target, set<int> fibonacci){
  2.         if(fibonacci.find(target) != fibonacci.end()){
  3.                 return {target};
  4.         }
  5.         auto it = lower_bound(fibonacci.begin(), fibonacci.end(), target);
  6.         vector<int> res = findSeries(target - *it, fibonacci);
  7.         res.push_back(*it);
  8.         return res;
  9. }
复制代码



算法的正确性 只要你理解任何数都可以用斐波那契数列和来表示 就能明白了


补充内容 (2018-12-31 09:10):
这里 auto it = lower_bound(fibonacci.begin(), fibonacci.end(), target);
这行应该改成找到数列里最大的小于target的数 不能用lower_bound 但核心思想就是这样
回复

使用道具 举报

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

本版积分规则

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