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

airbnb 一道电面题

全局:

2015(10-12月) 码农类General 硕士 全职@airbnb - 网上海投 - 技术电面  | | Pass | 在职跳槽

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

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

x
农友们已经提到过的, iterator of a 2D array wi
您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
使用VIP即刻解锁阅读权限或查看其他获取积分的方式
游客,您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
VIP即刻解锁阅读权限查看其他获取积分的方式
Unlock interview details and practice with AI
Curated Interview Questions from Top Companies
目没有算法可言,但是很容易爬满虫子。。。

评分

参与人数 2大米 +13 收起 理由
Yan_Benjamin + 3 很有用的信息!
cjlm007 + 10 回答的很好!

查看全部评分


上一篇:Amazon OA1 面经
下一篇:Percolate oa面经

本帖被以下淘专辑推荐:

推荐
butterwang 2015-12-2 07:48:46 | 只看该作者
全局:
我写了一个,不知道对不对。
  1. import java.io.*;
  2. import java.util.*;

  3. public class Solution {
  4.   private List<List<Integer>> array;
  5.   private int rowId;
  6.   private int colId;
  7.   private int numRows;
  8.    
  9.   public Solution(List<List<Integer>> array) {
  10.     this.array = array;
  11.     rowId = 0;
  12.     colId = 0;
  13.     numRows = array.size();
  14.   }
  15.    
  16.   public boolean hasNext() {
  17.     if (array == null || array.isEmpty()) {
  18.       return false;
  19.     }
  20.      
  21.     while (rowId < numRows && (array.get(rowId) == null ||
  22.       array.get(rowId).isEmpty())) {
  23.       rowId++;
  24.     }
  25.      
  26.     return rowId < numRows;
  27.   }
  28.    
  29.   public int next() {
  30.     int ret = array.get(rowId).get(colId);
  31.     colId++;
  32.     if (colId == array.get(rowId).size()) {
  33.       rowId++;
  34.       colId = 0;
  35.     }
  36.      
  37.     return ret;
  38.   }
  39.    
  40.   public void remove() {
  41.     List<Integer> listToRemove;
  42.     int rowToRemove;
  43.     int colToRemove;
  44.      
  45.     // Case 1: if the element to remove is the last element of the row
  46.     if (colId == 0) {
  47.       rowToRemove = rowId - 1;
  48.       listToRemove = array.get(rowToRemove);
  49.       colToRemove = listToRemove.size() - 1;
  50.       
  51.       listToRemove.remove(colToRemove);
  52.     } else { // Case 2: the element to remove is not the last element
  53.       rowToRemove = rowId;
  54.       listToRemove = array.get(rowToRemove);
  55.       colToRemove = colId - 1;
  56.       listToRemove.remove(colToRemove);
  57.     }
  58.      
  59.     // If the list to remove has only one element
  60.     if (listToRemove.isEmpty()) {
  61.       array.remove(listToRemove);
  62.       rowId--;
  63.     }
  64.      
  65.     // Update the colId
  66.     if (colId != 0) {
  67.       colId--;
  68.     }
  69.   }
  70.    
  71.   public static void main(String[] args) {
  72.     List<List<Integer>> array = new ArrayList<>();
  73.     List<Integer> row1 = new ArrayList<>();
  74.     row1.add(1);
  75.     row1.add(2);
  76.     row1.add(3);
  77.      
  78.     array.add(row1);
  79.      
  80.     List<Integer> row3 = new ArrayList<>();
  81.     array.add(row3);
  82.      
  83.     List<Integer> row2 = new ArrayList<>();
  84.     row2.add(4);
  85.     row2.add(5);
  86.     array.add(row2);
  87.      
  88.     Solution sol = new Solution(array);
  89.     while (sol.hasNext()) {
  90.       int result = sol.next();
  91.       System.out.println(result);
  92.       
  93.       if (result == 3) {
  94.         sol.remove();
  95.       }
  96.     }
  97.      
  98.     System.out.println();
  99.      
  100.     for (List<Integer> row : array) {
  101.       for (Integer elem : row) {
  102.         System.out.println(elem);
  103.       }
  104.     }
  105.   }
  106.    
  107. }
复制代码
回复

使用道具 举报

推荐
chaosMonkey 2016-10-16 19:44:35 | 只看该作者
全局:
Laurinda93 发表于 2016-7-22 07:09
我和层主有着同样的困惑;不知道你的思路有写过代码吗?

我觉得他的意思是  因为remove只能在next之后调用,而且iterator的更新是在每次调用next的时候更新的, 也就是说调用一次next后,iterator要么指向这一行中间的某个元素,要么指向这一行的end,这时调用remove的话,只要删掉当前iterator的前一个iterator就可以了,当然如果是C++的话,删除的结果应该再赋值给遍历用的iterator
回复

使用道具 举报

🔗
LifeGoesOn 2015-11-29 08:53:36 | 只看该作者
全局:
爬满虫子这个term 我还用了几秒反应是什么意思。。。
回复

使用道具 举报

🔗
fsi206914 2015-12-1 15:06:34 | 只看该作者
全局:
remove 直接 调用next(),可以么?
回复

使用道具 举报

🔗
yjfox 2015-12-2 13:11:20 | 只看该作者
全局:
butterwang 发表于 2015-12-2 07:48
我写了一个,不知道对不对。

如果是List<List<Integer>>这样的数据结构,可以用List的iterator,wrap一下就成了iterator of iterator。代码不超过30行
回复

使用道具 举报

🔗
joseph5wu 2016-2-12 11:28:29 | 只看该作者
全局:
yjfox 发表于 2015-12-2 13:11
如果是List这样的数据结构,可以用List的iterator,wrap一下就成了iterator of iterator。代码不超过30行 ...

这样子就不太好删除元素了
回复

使用道具 举报

🔗
yjfox 2016-2-12 12:51:10 | 只看该作者
全局:
joseph5wu 发表于 2016-2-12 11:28
这样子就不太好删除元素了

iterator的remove() 一并wrap
回复

使用道具 举报

🔗
aifer 2016-2-12 14:28:38 | 只看该作者
全局:
降维或者wrap
回复

使用道具 举报

🔗
joseph5wu 2016-2-12 14:31:48 | 只看该作者
全局:
yjfox 发表于 2016-2-12 12:51
iterator的remove() 一并wrap

iterator的话如果上一次next的时候正好换成了下一个原来iterator的开始,这样remove是不是就无法处理了
回复

使用道具 举报

🔗
yjfox 2016-2-12 21:12:11 | 只看该作者
全局:
joseph5wu 发表于 2016-2-12 14:31
iterator的话如果上一次next的时候正好换成了下一个原来iterator的开始,这样remove是不是就无法处理了

如果你说的是remove一个list中的第一个,那并不影响,删了还是可以next到下一个
如果你说的是remove一个list中的最后一个,那更不影响next到下一个list

不知道是否理解了你说的
回复

使用道具 举报

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

本版积分规则

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