《数据科学面试40+真题讲解》,K神本年度最后一次开课


一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
码农求职神器Triplebyte:
不用海投,内推你去多家公司面试
Airbnb 数据科学职位
in analytics and inference
天天打游戏、照样领工资,
你要不要来?
把贵司招聘信息放这里
查看: 1887|回复: 7
收起左侧

google电面面经

[复制链接] |试试Instant~ |关注本帖
kennethinsnow 发表于 2015-11-26 12:04:58 | 显示全部楼层 |阅读模式

2015(7-9月) 码农类 博士 全职@Google - 内推 - 技术电面 |Pass在职跳槽

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

您需要 登录 才可以下载或查看,没有帐号?Sign Up 注册获取更多干货

x
打电话,就在google doc出题写码。题目不难但是都很长。
. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
1. List ways you can use an int[] to keep track of a bunch of integers so that you can quickly answer the question if a particular integer is in that bunch.

To conceptualize:
class X {
  int[] storage;
  // other members if you like, but main storage should be int[]
  
  X(Collection<Integer> numbers) {
    // Setup
  }

   public boolean contains(int v) {
     // this needs to be fast
   }
}

Provide complexities (big-O notation) of lookup, storage required, and storage setup time.


lookup O(?)
storage required
storage setup O(?)
Straight copy
n
n
n
Sorting
log n
n
n log n
Bit compression
n
½ n
n
Hashing
1
2n
n
Bit vector
1
range/32
n


numbers % capacity
Range 1000-10000
9000 -> 14 bits instead of 32 bits

2. Given a tool to inspect classes for their dependencies, can you design an algorithm to determine the complete transitive closure of a set of classes?
只需实现analyze method,就是一个BFS. From 1point 3acres bbs
public interface ClassParser {
  Collection<Classname> parse(ZipInputStream inp, Classname classname);
}


public class Analyzer {
  private Parser parser;
  private Map<Classname, File> catalog;

  public Analyzer(Map<Classname, File> catalog,
      ClassParser parser) {
    this.catalog = catalog;
    this.parser = parser;
  }

  public static Collection<Classname> analyze(Iterable<Classname> toAnalyze,
      Map<Classname, File> catalog,
      ClassParser parser) {
    // Ignore this for now
  }

  public Collection<Classname> analyze(Iterable<Classname> toAnalyze) {
    Queue<Classname> myQue = new LinkedList<>(toAnalyze);
    Set<Classname> mySet = new HashSet<>(toAnalyze);
    while(!myQue.isEmpty()){
      Classname cur = myQue.poll();
      for(Classname ccl : findDependencies(cur)) {
        if(!mySet.contains(ccl)){
           mySet.add(ccl);
          myQue.offer(ccl);
        }
      }
    }
    return mySet;
  }

  private Collection<Classname> findDependencies(Classname toAnalyze) {
    ...
  }
}

. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
Example:
toAnalyze = A.class, B.class

calling findDependencies for A.class returns C.class, D.class
calling findDependencies for B.class returns C.class, E.class
calling findDependencies for C.class returns D.class, F.class
calling findDependencies for D.class returns E.class, F.class
calling findDependencies for F.class returns E.class
calling findDependencies for E.class returns {empty collection}

You should return: A.class,B.class,C.class,D.class,E.class,F.class (in any order)

评分

1

查看全部评分

brian1118 发表于 2015-11-27 22:57:45 | 显示全部楼层
第二題不是DFS topology sort嗎?
回复 支持 反对

使用道具 举报

 楼主| kennethinsnow 发表于 2015-11-28 02:44:13 | 显示全部楼层
brian1118 发表于 2015-11-27 22:57
第二題不是DFS topology sort嗎?

DFS也可以,不过BFS算法更容易写. From 1point 3acres bbs

补充内容 (2015-11-28 04:13):
不过不能理解成topologic sort, 因为可能会有环。
回复 支持 反对

使用道具 举报

bobzhang2004 发表于 2015-12-1 11:46:30 | 显示全部楼层
kennethinsnow 发表于 2015-11-28 02:44
DFS也可以,不过BFS算法更容易写

补充内容 (2015-11-28 04:13):

. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴这完全不是topological sort啊,是weak component吧?
回复 支持 反对

使用道具 举报

bobzhang2004 发表于 2015-12-1 11:47:17 | 显示全部楼层
楼主第一题最后就是自己用array实现一个hashmap?
回复 支持 反对

使用道具 举报

 楼主| kennethinsnow 发表于 2015-12-1 12:20:28 | 显示全部楼层
bobzhang2004 发表于 2015-12-1 11:47
楼主第一题最后就是自己用array实现一个hashmap?

最好的叫bitmap/bit vector
就是比较几种结构的存储,查询,空间复杂度
回复 支持 反对

使用道具 举报

bobzhang2004 发表于 2015-12-1 13:08:59 | 显示全部楼层
kennethinsnow 发表于 2015-12-1 12:20
最好的叫bitmap/bit vector
就是比较几种结构的存储,查询,空间复杂度

好的,对bit vector不熟。。。
回复 支持 反对

使用道具 举报

 楼主| kennethinsnow 发表于 2015-12-1 13:44:31 | 显示全部楼层
bobzhang2004 发表于 2015-12-1 13:08
好的,对bit vector不熟。。。

我当时也不知道,不过他就是看一下你的分析能力。他告诉你这个结构之后你能分析出复杂度就行了
回复 支持 反对

使用道具 举报

本版积分规则

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明

custom counter

GMT+8, 2017-11-22 17:21

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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