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

请教fb一个面经题

全局:

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

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

x
看到很多面经有提到 那个
您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
使用VIP即刻解锁阅读权限或查看其他获取积分的方式
游客,您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
VIP即刻解锁阅读权限查看其他获取积分的方式
Unlock interview details and practice with AI
Curated Interview Questions from Top Companies
分感谢!


上一篇:巨婴ots 含一道没出现的新题
下一篇:redfin电面加onsite跪经
推荐
ivanyang 2017-11-24 07:38:21 | 只看该作者
全局:
两个sparse vector求点乘乘积。
基本做法是每个vector维护成{index -> value} 的hashtable, 复杂度是O(min(n, m)),但是hashtable会浪费额外空间。
空间优化方法是维护vector< pair<index, value>>。
回复

使用道具 举报

🔗
1jiaqi3 2017-11-24 12:43:59 | 只看该作者
全局:
同问。。感觉这题频率好高

评分

参与人数 1大米 +1 收起 理由
xiaotu666 + 1 是啊

查看全部评分

回复

使用道具 举报

🔗
nicezg 2017-11-24 13:21:24 | 只看该作者
全局:

  1. class Solution{
  2. public:
  3.         int dotProduct(vector<pair<int,int>>& v1,vector<pair<int,int>>& v2){
  4.                 int res=0;
  5.                 unordered_map<int,int> m;//key: position  value: val
  6.                 for(auto&& v:v1){
  7.                         m[v.first]=v.second;
  8.                 }
  9.                 for(auto&& v:v2){
  10.                         if(m.find(v.first)!=m.end()){
  11.                                 res+=v.second*m[v.first];
  12.                         }
  13.                 }
  14.                 return res;
  15.         }
  16. };

  17. class Solution2{
  18. public:
  19.         int dotProduct(vector<pair<int,int>>& v1,vector<pair<int,int>>& v2){
  20.                 sort(v1.begin(),v1.end(),[](pair<int,int> i,pair<int,int> j){
  21.                                 return i.first<j.first;
  22.                                 });
  23.                 sort(v2.begin(),v2.end(),[](pair<int,int> i,pair<int,int> j){
  24.                                 return i.first<j.first;
  25.                                 });
  26.                 int i=0,j=0,res=0;
  27.                 while(i<v1.size()&&j<v2.size()){
  28.                         if(v1[i].first<v2[j].first)
  29.                                 i++;
  30.                         else if(v1[i].first>v2[j].first)
  31.                                 j++;
  32.                         else{
  33.                                 res+=v1[i].second*v2[j].second;
  34.                                 i++;
  35.                                 j++;
  36.                         }
  37.                 }
  38.                 return res;
  39.         }
  40. };
复制代码
回复

使用道具 举报

🔗
 楼主| wgxwxy 2017-11-24 13:33:53 | 只看该作者
全局:
懂了!谢谢各位!
回复

使用道具 举报

🔗
blactangeri 2017-11-24 16:39:56 | 只看该作者
本楼:
全局:
mark。。。。
回复

使用道具 举报

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

本版积分规则

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