拼多多算法岗笔试python解决方案

AC了前三道题,最后一题通过60%,最后一题的解法只通过了线下测试,没有验证

1、 数字山谷:从每个位置向向两边扩展,找到最大山谷,注意边界即可

xx = raw_input()[1:-1]
if xx == '':
    print 0
else:
    x = map(int,xx.split(','))
    n = len(x)

    if n < 3:
        print 0
    else:
        res = 0
        for i in xrange(1,n-1):
            l = i
            while l > 0 and x[l-1]>x[l]:
                l -= 1
            r = i
            while r < n-1 and x[r+1]>x[r]:
                r += 1
            if l < i and r > i:
                res = max(res,r-l+1)
        print res if res >= 3 else 0

2、 字符串构造:假设总串s长度为n,基串base长度为k,如果s/k * base + base[:s%k]==s,则返回(应该有更好的解法)

s = raw_input()
n = len(s)
for i in xrange(1,n+1):
    base = s[:i]
    if base * (n/i) + base[:n%i] == s:
        print base
        break

3、 到达指定位置:

分情况讨论:到target与到abs(target)的情况是一样的
        1. total = 1+2+...+k,求total刚好大于等于n的k,可知到达target至少要用k步,此时超出d=total-k
        2. 如果d为偶数,则只需将d/2步反向即可,k步即可到达target
        3. 如果d为奇数,则k步不可能到达,因为任何反转都会改变偶数距离,不可能消去d,则再走一步判断d+k+1是否为偶数
        4. 如果为偶数,说明k+1步可到
        5. 如果d+k+1为奇数,且已知d为奇数,说明k+1为偶数,不可能在k+1步走到,再走一步,d+k+1+k+2必为偶数,k+2步可到
def solve(target):
    import math
    n = abs(target)
    k = int(math.ceil(((8*n+1)**0.5-1)/2.))
    total = k*(k+1)/2
    d = total - n
    if d % 2 == 0:
        return k
    elif (d+k+1) % 2 == 0:
        return k + 1
    else:
        return k + 2

n = input()
print solve(n)

4、靓号:统计每个数字出现次数counter,以每个数字为基准,按照与基准差值对counter排序,优先替换差值小的数字;关于字典序的问题,如果替换的数比基准大则从前向后替换,如果替换的数比基准大,则从后向前替换,得到的就是字典序最小的字符串,时间复杂度O(n)

n,k = map(int,raw_input().split())
x = raw_input()

dic = Counter(map(int,x))


res = float('inf')
ans = []
for num,cnt in dic.items():
    need = k - cnt
    if need <= 0:
        print 0
        print x
        break
    else:
        tmp = [[xx,dic[xx]] for xx in dic if xx != num]
        tmp.sort(key=lambda y:abs(num-y[0]))
        w = 0
        cur = {}
        ii = 0
        while need > 0:
            act = min(tmp[ii][1], need) 
            cur[tmp[ii][0]] = act
            need -= act
            w += abs(num-tmp[ii][0]) * act
            ii += 1
        if w <= res:
            x_cp = x
            for g,gn in cur.items():
                if g > num:
                    x_cp = x_cp.replace(str(g),str(num),gn)
                if g < num:
                    x_cp = x_cp[::-1].replace(str(g),str(num),gn)[::-1]

            if w == res:
                ans.append(x_cp)
            else:
                ans = [x_cp]
                res = w

print res
print sorted(ans)[0]
#笔试题目##拼多多##秋招##Python#
全部评论
4 时间复杂度nlogn吧,用排序了,我是枚举最小-最大数字之间的每种情况,感觉也许有一些bad case是在中间某个值呢
点赞 回复 分享
发布于 2018-07-23 08:38
大佬简洁的代码
1 回复 分享
发布于 2018-07-23 11:23
你好,能贴出题目么
点赞 回复 分享
发布于 2018-08-05 15:50
拼多多在26号19.00会做一个线上技术分享会,对技术部架构和岗位感兴趣的同学,想拿拼多多技术部offer的同学可以关注一下~~ 分享会链接在这里:  https://m.qlchat.com/topic/2000001645751647.htm?pro_cl=4
点赞 回复 分享
发布于 2018-07-25 22:28
第一题leetcode原题,从左往右和从右往左分别遍历一遍数组即可,用两个临时数组分别记录两个方向的最长子串,最后两个临时数组的值相加取最大
点赞 回复 分享
发布于 2018-07-24 09:54
最后一题当原始号码已满足靓号时,输出不对,可以先对 Counter 排序,从最大的cnt开始遍历,最后两行输出时再做个检查就可以了。
点赞 回复 分享
发布于 2018-07-23 15:46
老哥稳
点赞 回复 分享
发布于 2018-07-23 11:18
大佬
点赞 回复 分享
发布于 2018-07-22 23:46
题目呢
点赞 回复 分享
发布于 2018-07-22 23:42
第一题这个复杂度竟然能过10的8次
点赞 回复 分享
发布于 2018-07-22 23:27
厉害了!
点赞 回复 分享
发布于 2018-07-22 22:54
大佬
点赞 回复 分享
发布于 2018-07-22 22:34

相关推荐

牛至超人:您好,京东物流岗了解一下吗?负责精加工食品的端到端传输
点赞 评论 收藏
分享
2025-12-27 16:21
已编辑
门头沟学院 Java
bg:中下211本科,java后端,无竞赛,无基础,大一升大二暑假开始学java。五段实习:美团-小红书-腾讯-淘天-字节。面秋招的简历只有美团、小红书、淘天。刚刚发现我的秋招蚂蚁流程挂了,这是我最后一个流程,那么我的秋招就算彻底结束了,总结一下:字节ssp+,职级2-1。美团ssp,+2打了半小时微信电话极力挽留。快手ssp,但报了字节薪资后没有争取的想法了。小红书sp,今年小红书给的很高,但比字节2-1还是差很多。虾皮应该是小sp?对虾皮一点意向都没,纯拿来集邮了。淘天ssp(暑期转正),说不要我的三方,毕业前考虑好了随时可以不签三方选择淘天。挂了的流程:京东二面挂,估计学历被卡了。懂车帝一面挂,和面试官聊不来,不认同我的方案。拼多多hr面挂,问我低于预期还来不来,当时说不考虑了,估计觉得我不忠诚。蚂蚁hr面挂,聊的还行,但估计我不会去给我挂了吧。阿里控股一面挂,没面前就知道是kpi了,因为时间可选的很多,而且都是半小时,我也拿他刷我的kpi了。上面差不多是我的情况,下面是我想说的话。我觉得我不算特别突出优秀的那类人,但我多少也算是靠前的那一批人,即使这样,秋招也不算特别顺利,也有挂了的流程,但你能说是我的问题吗,我觉得大部分情况不是的,如果真的是我的问题,我不可能本科校招拿到2-1,所以很多面试挂了,问题不出在面试者身上,很多是看运气+眼缘+和面试官合不合得来。所以我觉得,学会察言观色,了解面试官的脾性,也是面试很重要的一个点。比如面试官是喜欢听长回答,还是听短回答,他更看重哪些点,每个面试官对这些的侧重都是不一样的,所以作为面试者,要学会察言观色,通过面试官开局的一两个问题以及你回答后他的表现,就要判断出来。像我现在其实面试开局个五分钟,我就基本能判断个七七八八了,然后我后面的回答就会有所变化。这是我想说的第一个点:不要为面试结果焦虑,有时候问题不出在你身上,但你可以学一些面试技巧,尽量提高你的面试通过率,这里说的面试技巧指的不是网上那种烂大街的,一两分钟短视频说什么提高你面试通过率的,而是你要在你自己的面试过程中不断总结经验,吸取教训,旁人教你的终究是有限的。另外想说下选offer的事,上面其实可以看出来,我秋招最后是选了字节的,还没签三方我就来提前实习感受业务了,当我签完三方又过了一个多月,我这些天又在想这个问题,字节真的是我想要的吗,我现在总结了一下字节的好坏,发现当时可能被字节的高薪资影响判断了,如果现在再选一次的话,我应该会选杭州的小红书,会生活的更舒服点。具体种种就不展开说了。然后虽然我现在也可以说去把小红书舔回来,去毁字节,但我觉得没必要这么做,我可以采用其他的措施去不就,比如规划好两年内就跳槽,跳到杭州,跳到更舒适的城市。我觉得大家选offer的时候,真的可以冷静下来多方面考虑,薪资、城市、组内氛围、业务、老板是否看重、组内情况、未来升职机会等等都是可以考虑的因素,虽然有的时候不管选哪个,都不会坏,但最好也别让自己后悔吧,即使真后悔了,我觉得也没必要过度美化没走过的路,想好补救措施即可。这是我想说的第二个点:冷静好好做选择,不管是offer还是其他。但人生容错率很大,即使选错了,也一定有补救措施。最后还想说一些成长上的东西,尤其是现在AI火热的时代。我觉得大家如果想提高自己,或者说在未来社招跳槽有竞争力,肯定是要学AI相关的东西的,不说要会多懂AI,至少也要了解基本概念,而且一定要学会用AI提效。我现在字节的mt和我说,他现在80%代码都是AI写的。而我最近也开始尝试用AI工具,感觉现在AI真的进步很多,挺聪明的了,我现在写需求基本都是先让AI写,我再人工review小改动一下就差不多了。我觉得「AI取代程序员」是个很远的话题,但是「AI取代不会用AI的程序员」,可能真的就是近两年的事了。而怎么去学习这块的内容,其实我也正在探索,我也是刚学AI的起步阶段,我觉得大家也要有自己的信息检索能力,而不是别人喂你什么,你才学什么,自己一个人就不会学了。这是我想说的第三个点:趁年轻,多学习提升自己,拥抱AI,不要原地踏步,原地踏步的程序员最容易被淘汰。大概就是这样吧,今天看蚂蚁流程发现挂了,前几天腾讯约面我也拒了,就想到自己的秋招/校招算彻底结束了,有感而发,随便聊了下。牛客以后应该不会更新,大家不用关注,熟悉我的朋友应该知道我在其他平台有号。我更喜欢以长视频的形式去做分享,感觉会更有体系,而不是网上那种一两分钟的零碎短视频的那种营销号去起号,我也推荐大家多去看高质量的长文章、长视频,我觉得收获的能更多。希望大家能收获满意的offer与未来。
CEXBB:刷到最后才发现原来是优雅✌🏻,我的Java引路人
2025年终总结
点赞 评论 收藏
分享
评论
8
86
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务