0813 微软第二次笔试

1、处理排污问题,一个数组A代表排污的量,加一台处理污染的机器,排污量减少一半,问最少几台机器能把排污量减少一半,
实现函数public int solution(int[] A)
用例:A[5,8,19,1],返回3,2台机器处理19(19/2/2),1台机器处理8(8/2),19/2/2 + 8/2 + 5 + 1 = 14.75 < 33(A数组得和)
2、统计分数和为1的个数,两个数组X, Y分别代表分子、分母,统计有多少对和为1的分数,
实现函数public int solution(int[] X, int[] Y)
用例:X[1,1,1], Y[2,2,2],代表3个1/2,共有3对
3、病人复健,在接下来的N天(0-N-1)有x节复健课,在第i天复健消费A[i],每节复健课(除最后一节课),下一次都一定在第Y天后,问最小的复健开销是多少。
实现函数:public int solution(int[] A, int X, int Y)

思路:
1、使用最大堆存储污染记录,并记录污染的总和,每次都处理最大的污染数,直到总和小于原总污染的一半
2、写一个函数判断分数的和是否为1然后遍历就行,注意边界值,int肯定溢出了,额,这是否有点简单了,(感觉事情没有这么美好)
3、没想到什么好思路,直接暴力遍历。
#笔经#
全部评论
第三题可以用前缀数组
点赞 回复 分享
发布于 2022-08-13 14:29
第二题我用的分子分母最大公约数存了一下,不然O(n^2)是不是太慢了
点赞 回复 分享
发布于 2022-08-13 18:08
第三题可以考虑用sliding window
点赞 回复 分享
发布于 2022-08-14 17:32
请问怎么参加两次笔试要申请吗
点赞 回复 分享
发布于 2022-08-19 15:00 安徽

相关推荐

牛舌:如果我不想去,不管对方给了多少,我一般都会说你们给得太低了。这样他们就会给下一个offer的人更高的薪资了。
点赞 评论 收藏
分享
昨天 11:23
重庆邮电大学 C++
点赞 评论 收藏
分享
点赞 1 评论
分享
牛客网
牛客企业服务