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

Facebook电面

全局:

2018(10-12月) 码农类General 博士 全职@meta - 内推 - 技术电面  | | Other | 应届毕业生

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

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

x
面试官是华人小美女,很nice~
题目是一个包含0和1的matrix,大概是这样[[0 1 1 1], [0 0 0 1]
您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
使用VIP即刻解锁阅读权限或查看其他获取积分的方式
游客,您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
VIP即刻解锁阅读权限查看其他获取积分的方式
Unlock interview details and practice with AI
Curated Interview Questions from Top Companies
一次电面,还是太紧张了,最后很多corner case没写好。

评分

参与人数 4大米 +7 收起 理由
julius1121 + 1 赞一个
wszcas + 2 给你点个赞!
lukuang + 1 给你点个赞!
drool + 3 给你点个赞!

查看全部评分


上一篇:非死不可上门
下一篇:Google summer intern Team match求捞+timeline和面经

本帖被以下淘专辑推荐:

🔗
daidaixiong 2018-12-8 15:01:53 | 只看该作者
全局:
楼主,这题是不是每次对中间那一列进行线性扫描,如果发现1就然后继续在左侧的列中寻找;否则就在右侧的列中寻找;复杂度是row*log(col)
回复

使用道具 举报

🔗
daidaixiong 2018-12-8 15:15:37 | 只看该作者
全局:
写了一个,大家看看有没有问题,求加点米~~
#include <vector>
#include <iostream>
using namespace std;

int leftMostColumn(vector<vector<int> >& nums) {
        int row = nums.size();
        if (row==0||nums[0].size()==0||nums[0].size()==1)
                return -1;
        int col = nums[0].size();
        int i = 0;
        int j = col-1;
        while (i<=j) {
                int mid = i+(j-i)/2;
                bool flag = false;
                for (int k = 0; k<row; ++k) {
                        if (nums[k][mid]==1) {
                                flag = true;
                                break;
                        }
                }
                if (flag) {
                        j = mid-1;
                }
                else {
                        i = mid+1;
                }
        }
        if (i==0)
                return -1;
        return i;
}

int main() {
        vector<vector<int> > nums;
        nums.push_back(vector<int>{0, 0, 1, 1});
        nums.push_back(vector<int>{0, 0, 0, 1});
        nums.push_back(vector<int>{0, 0, 1, 1});
        nums.push_back(vector<int>{0, 0, 0, 0});
        cout << leftMostColumn(nums) << endl;
        return 0;
}

评分

参与人数 1大米 +3 收起 理由
wangyandan418 + 3 给你点个赞!

查看全部评分

回复

使用道具 举报

🔗
uggl233 2018-12-9 06:04:08 | 只看该作者
全局:
从右上开始找 复杂度可以优化到 O(row + col)

评分

参与人数 1大米 +3 收起 理由
daidaixiong + 3 给你点个赞!

查看全部评分

回复

使用道具 举报

🔗
 楼主| wangyandan418 2018-12-9 06:37:06 | 只看该作者
全局:
daidaixiong 发表于 2018-12-8 15:01
楼主,这题是不是每次对中间那一列进行线性扫描,如果发现1就然后继续在左侧的列中寻找;否则就在右侧的列 ...

是哈,针对每一行使用binary search,复杂度就是row*log(col),要注意考虑某一行全零和整个matrix全零的情况
回复

使用道具 举报

🔗
 楼主| wangyandan418 2018-12-9 06:38:06 | 只看该作者
全局:
uggl233 发表于 2018-12-9 06:04
从右上开始找 复杂度可以优化到 O(row + col)

哇,谢谢指点,具体怎么操作呢?
回复

使用道具 举报

🔗
uggl233 2018-12-9 14:30:02 | 只看该作者
全局:
wangyandan418 发表于 2018-12-9 06:38
哇,谢谢指点,具体怎么操作呢?

就从右上方开始找呀 如果是0的话 就往下走 说明这一行没什么好研究的了 如果是1的话 说明是potential col 就往左走咯一直走到底为0后然后再往下看 这算法很intuitive吧.. 老哥你纸上画一下就知道了

评分

参与人数 1大米 +3 收起 理由
TinaTinaTina96 + 3 欢迎来一亩三分地论坛!

查看全部评分

回复

使用道具 举报

🔗
uggl233 2018-12-9 14:30:23 | 只看该作者
全局:
wangyandan418 发表于 2018-12-9 06:38
哇,谢谢指点,具体怎么操作呢?

有帮助的话 加个米哈哈

评分

参与人数 1大米 +3 收起 理由
wangyandan418 + 3 给你点个赞!

查看全部评分

回复

使用道具 举报

🔗
TinaTinaTina96 2018-12-13 15:43:38 | 只看该作者
全局:
uggl233 发表于 2018-12-9 14:30
就从右上方开始找呀 如果是0的话 就往下走 说明这一行没什么好研究的了 如果是1的话 说明是potential col ...

谢谢你啊!
回复

使用道具 举报

全局:
#include <vector>
#include <iostream>
using namespace std;

int leftMostColumn(vector<vector<int> >& nums) {
    int res = nums[0].size();
    for(int i = 0; i< nums.size(); i++){
        int l = 0, r = nums[i].size() - 1;
        while(l+1<r){
            int mid = l + (r-l)/2;
            if(nums[i][mid] == 1){
                r = mid;
            }else{
                l = mid;
            }
        }
        if(nums[i][l] == 1){
            res = min(l, res);
        }else if(nums[i][r] == 1){
            res = min(r, res);
        }
    }

    return res;
}

int main() {
    vector<vector<int> > nums;
    nums.push_back(vector<int>{0, 0, 1, 1});
    nums.push_back(vector<int>{0, 0, 0, 1});
    nums.push_back(vector<int>{0, 0, 1, 1});
    nums.push_back(vector<int>{1, 1, 1, 1});
    cout << leftMostColumn(nums) << endl;
    return 0;
}
O(m*log(n))的时间复杂度算法 有帮助的话加个米 也能写一个O(m+n)的算法

评分

参与人数 1大米 +3 收起 理由
wangyandan418 + 3 很有用的信息!

查看全部评分

回复

使用道具 举报

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

本版积分规则

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