拼多多笔试 0526 24届算法

有点伤感秋招不努力,都要毕业了这个时间点还在做笔试,按道理应该是去度假的。

第一题题意: 给定一个长度为n (n < 1e5) 的序列以及一个数m(1 < m < 1e5),序列中每个数的范围为0~1e9,求所有的位置p使得序列前p个数包含k组1~m的所有值。比如n=9,m=4,序列为[2, 3, 4, 1, 5, 1, 2, 3, 4],答案输出4和9。
第一题做法:搞个数组存一下1~m出现的次数,标记表示一下有多少0变到1,每次加1,每当标记加到m,数组所有值减1,标记每当1变到0时减1。时间复杂度O(n)。

第二题题意:给定一个长度为n (n < 2e5)的01字符串以及操作次数m (<1e9),每个操作选择位置x,使得字符串位置x和位置x+1不变,其余位置全部翻转(0变为1,1变为0)。求操作完毕之后字符串对应二进制的最小值。
第二题做法:首先转化一下题意,操作可以变为:一、先将字符串所有位置翻转m次,二:进行m次翻转相邻两个位置的操作。对于第一步操作:当m为偶数时不变,奇数时翻转;对于第二步操作,从左到右贪心,为1时翻转。多余的操作就只动最后一位。时间复杂度O(n)

第三题题意:给定一个长度为n (n < 1e5) 的数组,进行q(<1e5)次对原数组的查询,问最小进行几次操作使得第k大的数为x (<1e9),每次操作可以选择数组的某个数加1。
第三题做法:(第k大等价于第l = n+1-k小)首先对数组进行排序,然后求前缀和,对于每次查询,二分查找找到第一个比x大的位置pos,答案为(pos - l + 1) * x - sum[pos] + sum[l - 1]。时间复杂度O(nlogn + qlogn)

第四题题意:给定p, q, n,(p, q <= n < 1e18),表示容量为n的容器,一开始存储为0,每次可以加p(剩余容量大于等于p)或者减去q(容器已有至少为q),当存在既不能加p也不能减q的情况输出Yes,否则No。
第四题做法:分类讨论一下,虽然表达式一样。当p > q时,No的情况为 p + q - gcd(p, q) > n。当p < q时,No的情况为 q + p - gcd(p, q) > n。时间复杂度O(log n)。
全部评论
太菜了我做了pdd的笔试才发现自己有多TMD菜
4 回复 分享
发布于 05-26 21:21 陕西
不给错误示例,太抽象
2 回复 分享
发布于 05-26 21:07 辽宁
解释一下第四题 其实就是要找到一个a*p - b*q=x,使得x+p>n且x<q 众所周知a*p-b*q=c*gcd(p,q)所以转化为p+q-gcd(p,q)>n 因为满足x<q的最大的x是q-gcd(p,q)
2 回复 分享
发布于 05-26 23:30 重庆
大佬牛逼!
1 回复 分享
发布于 05-26 20:36 浙江
第一题 我用哈希表维护,示例都对的,但还是0%,这是为啥啊
1 回复 分享
发布于 05-26 20:57 上海
大佬,第四题能详细说一下吗。或者说用到了哪条数论定理呢
1 回复 分享
发布于 05-26 21:11 天津
第二题为啥这么做是对的啊。我想的是,对于每次翻转的字符串,找到字符串中第一个0的位置i,把i和i+1以外的位置翻转,这样能保证每次翻转后得到的字符串是最小的。重复m次得到结果,测试用例能过但是通过率0%😥
1 回复 分享
发布于 05-26 21:14 湖北
我也有点伤感,我感觉我思路没问题,一提交就0
1 回复 分享
发布于 05-26 21:14 浙江
第四题看着像裴属定理, 但是题目还有个条件就是执行一些操作后的数是在0~n之间的, 但是好像没有考虑这个问题, 然后推出了这个公式? 想问下大佬第四题全A了吗
1 回复 分享
发布于 05-26 21:52 吉林
第三题思路差不多但是只过了2.5%
点赞 回复 分享
发布于 05-26 21:01 黑龙江
话说第四题为什么是gcd,没搞懂
点赞 回复 分享
发布于 05-26 21:16 陕西
有无大佬解释一下第四题的答案
点赞 回复 分享
发布于 05-26 21:16 广东
第二题的思路没想到,tql大佬
点赞 回复 分享
发布于 05-26 21:17 江苏
为什么pdd实习的笔试和春招的是一样的?
点赞 回复 分享
发布于 05-26 21:26 山东
佬,第四题为啥求公约数
点赞 回复 分享
发布于 05-26 21:35 山西
pdd现在还在招吗,看官网上都没有技术岗了
点赞 回复 分享
发布于 05-29 11:29 四川

相关推荐

10-12 11:00
点赞 评论 收藏
分享
一面:自我介绍。询问项目(大学生科创),问了项目中用的算法,程序不是本人负责,所以只能如实回答不了解。对一些智驾术语熟悉吗,ACC,LCC。谈一下对ADAS的理解。提前准备回答得七七八八。Linux系统的常见命令,忘记了答得不好。C11的特性是什么,没有回答出来。询问实习经历——美团外卖柜运维,基本是柜机的手工保障,如实回答,这里聊了很长时间。介绍你的专业课。简单问了比赛经历。对自动驾驶的理解。询问能否接受到岗时间、工作内容等。总结:一面整体回答的不是很好,非常多专业问题都没有答出来,但是面试小哥哥人很好,聊了一个小时左右。面完后马上就安排了二面。二面:还是自我介绍。还是问了项目,这次做了准备,提问时域信号如何转换成频域信号。傅里叶变换的原理是什么。原理没有回答出来。问Linux的基础命令,一面经验提前复习,自己觉得答得还行。询问了美团外卖柜实习的经历,如实回答,没有问过多技术内容。让当面手撕代码题。力扣medium难度,“给你一个字符串表达式&nbsp;s&nbsp;,请你实现一个基本计算器来计算并返回它的值。注意:不允许使用任何将字符串作为数学表达式计算的内置函数,比如&nbsp;eval()&nbsp;。”旷视2025届校招启动啦!这是面向全球高校毕业生推出的一项尖端人才招募计划九个职位,两大城市米哈游招聘期待最优秀的你与我们一起共同打造AI新纪元!【网申地址】https://app.mokahr.com/campus_apply/megviihr/38642?recommendCode=DS87a6UM#/jobs【内推码】DS87a6UM投递的uu留言下姓名缩写和岗位,我会尽力跟进~(czy+产品经理)
旷视
|
校招
|
73个岗位
点赞 评论 收藏
分享
评论
18
35
分享
牛客网
牛客企业服务