12
返回列表 发新帖
楼主: 匿名
跳转到指定楼层
上一主题 下一主题
收起左侧

空气床挂经

🔗
鹿科42 2025-8-14 12:36:49 | 只看该作者
全局:
kratosyl 发表于 2025-8-7 01:39
我感觉是 当date range给出之后,每个listing最有左右两个连续的range,一个cover start date, 一个cover e ...

想一块去了。
建两个SortedList A和B
A存x,代表3~(x-1)available
B存y,代表y~11 available
第一步分析input
用二分找3,找到3往后数,发现到x-1之后就不连续了,存A(id,x)
再二分找11,找到11往前数,发现到y,存B(id,y)
第二步 寻找匹配
在B.Values里找A.Values[i] + 1,如果B.Values[j] = A.Values[i] + 1,则Airbnb A.Key[i] 可以匹配任意 Airbnb B.Key[0] ~ B.Key[j - 1]

两步都是O(nlogn),最差情况是O(n2)发生在全匹配时,发生在生成匹配结果的时候。
回复

使用道具 举报

地里匿名用户
🔗
匿名用户-XOYZZ  2025-8-21 03:58:04
面試遇到這題,我只想放棄....
回复

使用道具 举报

全局:
我问了一下chatGPT,他给了一个很好的角度。在最多的可能性下,答案的数量级是n^2,所以你不可能设计出时间复杂度低于这个的算法。(PS,可能的答案数量本质上是一个组合问题,从n个选项中选择2个出来,这种C n 2 问题的答案有 n*(n-1)/2 种)。
回复

使用道具 举报

地里匿名用户
🔗
匿名用户-FYRIK  2025-8-30 00:55:52
kratosyl 发表于 2025-8-7 11:09
我感觉是 当date range给出之后,每个listing最有左右两个连续的range,一个cover start date, 一个cover e ...

Worst case is: O(n*n)
回复

使用道具 举报

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

本版积分规则

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