查看: 1043|回复: 1
收起左侧

Compass Karat 面经 新题

|只看干货
匿名用户-22B  发表于 2021-7-15 00:18:56 |阅读模式
本楼: 👍   100% (1)
 
 
0% (0)   👎

2021(7-9月) FrontEndEng 硕士 全职@Compass - 网上海投 - 技术电面  | Other | 在职跳槽

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

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

x
昨天刚完成的Karat面,一个黑人小哥,前5分钟互相介绍,之后的15分钟一直在问我以前做的项目。问的比较详细,需要讲一个觉得做的不错的项目,说清楚项目的架构,我完成的是那个部分,遇到了什么困难,怎么解决的。
之后的40分钟写题。我面的这个题不是简书的这个总结里的https://www.jianshu.com/p/fdbcba5fe5bc 但跟那个门禁卡的题比较像,不知道是不是新题。一共两道。我申请的前端职位,所以用JS写的。只是一个workable solution,比较糙,大家参考看看吧

第一题:
Suppose we have an unsorted log file of accesses to web resources. Each log entry consists of an access time, the ID of the user making the access, and the resource ID.

The access time is represented as seconds since 00:00:00, and all times are assumed to be in the same day.

Example:
logs1 = [
    ["58523", "user_1", "resource_1"],
    ["62314", "user_2", "resource_2"],
    ["54001", "user_1", "resource_3"],
    ["200", "user_6", "resource_5"],
    ["215", "user_6", "resource_4"],
    ["54060", "user_2", "resource_3"],
    ["53760", "user_3", "resource_3"],
    ["58522", "user_22", "resource_1"],
    ["53651", "user_5", "resource_3"],
    ["2", "user_6", "resource_1"],
    ["100", "user_6", "resource_6"],
    ["400", "user_7", "resource_2"],
    ["100", "user_8", "resource_6"],
    ["54359", "user_1", "resource_3"],
]

Expect Output:
[ { user_1: [ '54001', '58523' ] },
  { user_2: [ '54060', '62314' ] },
  { user_6: [ '2', '215' ] },
  { user_3: [ '53760', '53760' ] },
  { user_22: [ '58522', '58522' ] },
  { user_5: [ '53651', '53651' ] },
  { user_7: [ '400', '400' ] },
  { user_8: [ '100', '100' ] } ]

Example 2:
logs2 = [
    ["300", "user_1", "resource_3"],
    ["599", "user_1", "resource_3"],
    ["900", "user_1", "resource_3"],
    ["1199", "user_1", "resource_3"],
    ["1200", "user_1", "resource_3"],
    ["1201", "user_1", "resource_3"],
    ["1202", "user_1", "resource_3"]
]

Expect Output: [ { user_1: [ '300', '1202' ] } ]

第二题:

Write a function that takes the logs and returns the resource with the highest number of accesses in any 5 minute window, together with how many acce
您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
使用VIP即刻解锁阅读权限或查看其他获取积分的方式
游客,您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
VIP即刻解锁阅读权限查看其他获取积分的方式

  for (const [resource, times] of map) {
    times.sort((a, b) => parseInt(a) - parseInt(b));
    let temp = [...result];
    result[1] = Math.max(result[1], getFiveMinsMax(times));
    if (temp[1] !== result[1]) {
      result[0] = resource;
    }
  }
  return result;
}

var getFiveMinsMax = function(times) {
  if (!times || times.length == 0) {
    return 0;
  }
  let count = 0;
  // console.log({ times })
  for (let i = 0; i < times.length; i++) {
    let j = i + 1;
    var tempCount = 1;
    while (j < times.length && parseInt(times[j]) - parseInt(times) <= 300) {
      tempCount += 1;
      j++;
    }
    count = Math.max(tempCount, count);
  }
  return count;
}

console.log(getMax(logs1));


评分

参与人数 2大米 +22 收起 理由
yuanqijiong + 2 很有用的信息!
清道神君 + 20

查看全部评分


上一篇:Bloomberg莫名其妙挂经
下一篇:[求助] tik tok 分析岗4小时 take home assignment
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   100% (39)
 
 
0% (0)    👎
谢谢分享!
回复

使用道具 举报

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

本版积分规则

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