拼多多笔试 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)。
第一题题意: 给定一个长度为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菜
不给错误示例,太抽象
解释一下第四题
其实就是要找到一个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)
大佬牛逼!
第一题 我用哈希表维护,示例都对的,但还是0%,这是为啥啊
大佬,第四题能详细说一下吗。或者说用到了哪条数论定理呢
第二题为啥这么做是对的啊。我想的是,对于每次翻转的字符串,找到字符串中第一个0的位置i,把i和i+1以外的位置翻转,这样能保证每次翻转后得到的字符串是最小的。重复m次得到结果,测试用例能过但是通过率0%😥
我也有点伤感,我感觉我思路没问题,一提交就0
第四题看着像裴属定理, 但是题目还有个条件就是执行一些操作后的数是在0~n之间的, 但是好像没有考虑这个问题, 然后推出了这个公式? 想问下大佬第四题全A了吗
第三题思路差不多但是只过了2.5%
话说第四题为什么是gcd,没搞懂
有无大佬解释一下第四题的答案
第二题的思路没想到,tql大佬
为什么pdd实习的笔试和春招的是一样的?
佬,第四题为啥求公约数
pdd现在还在招吗,看官网上都没有技术岗了
相关推荐
点赞 评论 收藏
分享