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

抖音电面

🔗
匿名用户-H75CG  2020-12-1 10:22:43 |倒序浏览

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

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

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

x
抖音电面,两道题


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


但是这种方法复杂度很高,想了半天想不出来,最后面试官提示用PQ来解,当时没有想好该怎么处理duplicate了。
面完之后想了很久,应该是用一个map来记录每个数值的freq,先把所有的unique的num放入pq中,然后取出K个,更新map,如果map存的freq为0,则删除对应的数值。然后在把map中所有的keySet放入pq中,如果PQ取出不连续的数,则返回false

评分

参与人数 1大米 +9 收起 理由
匿名用户-RPUWP + 9

查看全部评分


上一篇:蓝鸟店面
下一篇:亚麻昂赛面经
地里匿名用户
推荐
匿名用户-H75CG  2020-12-1 12:20:24
gongchen 发表于 2020-12-1 12:12
哈哈 楼主你原文说是subarray然后用PQ我都懵了

不过我用PQ和map倒是把怡二酒陆写出来了,速度>70%貌似还可以,和discussion的高票答案不是一个解法。
  1. class Solution {
  2.     public boolean isPossibleDivide(int[] nums, int k) {
  3.         if(nums.length%k!=0) return false;
  4.         
  5.         PriorityQueue<Integer> pq = new PriorityQueue<>();
  6.         Map<Integer, Integer> info = new HashMap<>();
  7.         for(int num:nums) {
  8.             info.put(num, info.getOrDefault(num, 0)+1);
  9.         }
  10.         
  11.         pq.addAll(info.keySet());
  12.         
  13.         while(!pq.isEmpty()) {
  14.             int prev = 0;
  15.             List<Integer> list = new ArrayList<>();
  16.             
  17.             for(int i=0; i<k; i++) {
  18.                 if(pq.isEmpty()) return false;
  19.                 if(i==0) {
  20.                     prev = pq.poll();
  21.                     list.add(prev);
  22.                     info.put(prev, info.get(prev)-1);
  23.                     continue;
  24.                 } else {
  25.                     int tmp = pq.poll();
  26.                     if(tmp-prev>1) return false;
  27.                     info.put(tmp, info.get(tmp)-1);
  28.                     prev = tmp;
  29.                     list.add(tmp);
  30.                 }
  31.             }
  32.             
  33.             for(int num:list) {
  34.                 if(info.get(num)>0) {
  35.                     pq.offer(num);
  36.                 }
  37.             }
  38.         }
  39.         
  40.         return true;
  41.     }
  42. }
复制代码



评分

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

查看全部评分

回复

使用道具 举报

推荐
AlbertZhong 2020-12-1 10:59:57 | 只看该作者
全局:
感谢楼主分享。关于第2题,能否再详细地说以下题意?
1. “分成多个size为K的subarray“怎么理解?
  加入n=array.length, 给的条件一定满足n%k==0吗?(也就是恰好分成a0[0]...a[k-1], a[k]...a[2*k-1], ..., a[n-k]...a[n-1]这一共n/k个部分?)
2. ”subarray中的int值是连续的“怎么定义?
  例如,n=6, k=3, array = [1, 2, 3, 3, 5, 4]。这里的[3, 5, 4]算不算int值连续的?
回复

使用道具 举报

全局:
mchzh 发表于 2020-12-1 10:45
第二题是不是pq里面要存pair : val and idx ,两个都要排序,这题是不是还有扫描线的解法

LRU的multi thread实现可以加锁,或者使用thread safe的class都可以,网上应该有具体介绍

第二题pq我是只存num,map存num对应的freq。

回复

使用道具 举报

地里匿名用户
🔗
匿名用户-VQ6JT  2020-12-1 10:24:02 来自APP
谢谢楼主分享,请问面的是哪个组?
回复

使用道具 举报

🔗
mchzh 2020-12-1 10:37:43 | 只看该作者
全局:
LRU的multi thread就是加锁吗?多谢
回复

使用道具 举报

🔗
mchzh 2020-12-1 10:45:00 | 只看该作者
全局:
第二题是不是pq里面要存pair : val and idx ,两个都要排序,这题是不是还有扫描线的解法
回复

使用道具 举报

🔗
gongchen 2020-12-1 11:52:32 | 只看该作者
全局:
您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
使用VIP即刻解锁阅读权限或查看其他获取积分的方式
游客,您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
VIP即刻解锁阅读权限查看其他获取积分的方式
Unlock interview details and practice with AI
Curated Interview Questions from Top Companies



回复

使用道具 举报

🔗
mchzh 2020-12-1 12:02:22 | 只看该作者
全局:
夏虫何以语冰X 发表于 2020-12-1 11:14
LRU的multi thread实现可以加锁,或者使用thread safe的class都可以,网上应该有具体介绍

第二题pq我 ...

感觉map存freq会丢了index的位置信息
回复

使用道具 举报

地里匿名用户
🔗
匿名用户-H75CG  2020-12-1 12:03:06
gongchen 发表于 2020-12-1 11:52
**** 本内容被作者隐藏 ****

哈哈是的就是这个题。
回复

使用道具 举报

🔗
mchzh 2020-12-1 12:04:16 | 只看该作者
全局:
gongchen 发表于 2020-12-1 11:52
**** 本内容被作者隐藏 ****

那估计应该是subseqence,不是subarray
回复

使用道具 举报

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

本版积分规则

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