阿里面试经验总结

本文详细解答了三个编程问题:如何从多个数字中根据权重随机选择三个;LRU算法如何快速查找缓存内存块的命中情况;以及如何找出地铁站每天的最长进出站时间间隔。通过实例解析,帮助读者理解并解决相关问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

总共只问了三个问题,哎,都答得不咋样。
1. 从很多数字中随机选三个。每个数字都有一个权重,权重越大,选中的几率越大。

给的提示是,所有权重相加得到一个和,随机生成一个数,在和中所处的位置就是选取的值。比如,三个数11,22,33权重分别为1,2,3。然后相加得到的值为6,生成的数为1.3,则选取的数为22。

_
2. LRU算法,给你10G的cache,怎么快速找出内存块key是否命中。

用map保存key。交换队头与找到的key对应的块。(这一部分还需要补充)

_
3. 依据地铁站的进出站日志找出每天中的最长进出站时间间隔。文件很多。

归并排序。按序遍历,不用读取全部文件。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值