12
返回列表 发新帖
楼主: claireyangyang
跳转到指定楼层
上一主题 下一主题
收起左侧

新出炉的狗家电二面

🔗
yhatl 2016-10-9 03:02:51 | 只看该作者
全局:
int tmp=0;
vector<int> sum(nums.size(),0);
for(int i=0;i<nums.size();i++){
    sum[i]+=tmp+nums[i];
    tmp=sum[i];
}
return nums[upper_bound(sum.begin(),sum.end(),rand()%sum[sum.size()])-sum.begin()];
回复

使用道具 举报

🔗
木易wen 2016-10-19 23:44:23 | 只看该作者
全局:
partial sum 然后二分找区间?
回复

使用道具 举报

🔗
syjohnson 2016-10-31 09:44:20 | 只看该作者
全局:
xihaokai1 发表于 2016-10-7 00:22
存partial sums, 可以做到logn

求问详细思路,存完prefix sum之后如何logN查找呢
回复

使用道具 举报

🔗
warriorbrant 2016-11-3 10:18:43 | 只看该作者
全局:
  1. public static int find(int[] array){
  2.                 int[] sum=new int[array.length];
  3.                 sum[0]=array[0];
  4.                 for(int i=1;i<array.length;i++)sum[i]=array[i]+sum[i-1];
  5.                 int start=0;
  6.                 int end=sum.length-1;
  7.                 int location=-1;
  8.                 int target=(int)(Math.random()*(sum[array.length-1]-sum[0]+1))+sum[0];
  9.                 while(start<end){
  10.                         int mid=start+(end-start)/2;
  11.                         if(sum[mid]==target){
  12.                                 location=mid;
  13.                                 break;
  14.                         }else if(sum[mid]<target) {
  15.                                 start=mid+1;
  16.                         }else{
  17.                                 end=mid;
  18.                         }
  19.                 }
  20.                 if(location==-1)location=start;
  21.                 if(location==0)return sum[0];
  22.                 else return sum[location]-sum[location-1];
  23.                
  24.         }
复制代码
回复

使用道具 举报

全局:
想问一下 楼主, google 电话面试的话, 需不需要 在网上跑 (RUN)你的代码?
回复

使用道具 举报

🔗
huai10 2016-11-6 08:20:41 | 只看该作者
全局:
看来google还是喜欢考tree,特别各种BST
回复

使用道具 举报

🔗
Sorrow雨 2016-11-9 10:45:34 | 只看该作者
全局:
这题要求和怎么也得O(N)吧?
回复

使用道具 举报

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

本版积分规则

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