美团21.9.25笔试代码

第一题:旅游路线 100%
import os

T = int(input())
while T > 0:
    T-=1
    x = input().split(' ')
    x = [int(i) for i in x]
    n, m, k = x[0], x[1], x[2]
    mm = [[0]*n for i in range(n)]
    for i in range(m):
        x = input().split(' ')
        x = [int(j) for j in x]
        u, v = x[0], x[1]
        mm[u-1][v-1], mm[v-1][u-1] = 1, 1
    km = input().split(' ')
    km = [int(i) for i in km]
    result = "YES"
    for i in range(len(km)-1):
        u, v = km[i], km[i+1]
        if mm[u-1][v-1] == 1:
            continue
        else:
            result = 'NO'
            break
    print(result)
    

第二题:立方碑 100%
import os

def digui(a, pos, m, val, sm):
    if pos >= len(a):
        return False
    if val == sm:
        return True
    re = digui(a, pos+1, m, val, sm)
    if re:
        return re
    if m > 0:
        sm -= a[pos]
        sm += a[pos] ** 3
        if val == sm:
            return True
        else:
            return digui(a, pos+1, m-1, val, sm)
    return False

T = int(input())
while T > 0:
    T-=1
    x = input().split(' ')
    x = [int(i) for i in x]
    n, m, k = x[0], x[1], x[2]
    a = input().split(' ')
    a = [int(j) for j in a]

    result = digui(a, 0, m, k, sum(a))
    if result:
        print("YES")
    else:
        print('NO')
    

第三题:水桶效应 100%
import os

x = input().split(' ')
x = [int(i) for i in x]
n, m = x[0], x[1]
a = input().split(' ')
a = [int(j) for j in a]
a = sorted(a)
result = a[0]
pos = 0
for i in range(n-1):
    gap = a[i+1] - a[i]
    if gap == 0:
        continue
    if m <(i+1):
        break
    high = min(gap, int(m/(i+1)))
    m -= high * (i+1)
    result = a[i] + high
    pos = i
if m > 0 and pos == (n-2):
    high = int(m/n)
    result = a[-1] + high
print(int(result))

第四题:分小组,求最小极值  36% TLE
import os
global result
result = 1e18

def digui(a, pos, m, cur_res):
    global result
    if pos >= len(a):
        result = min(result, cur_res)
        return 
    n = len(a)
    if m == 0:
        return 
    if pos + m >= n:
        result = min(result, cur_res)
        return 
    mx = n - pos -m +1
    for i in range(1, mx+1):
        cur_a = a[pos:pos + i]
        cur_res += max(cur_a) - min(cur_a)
        digui(a, pos +i, m-1, cur_res)


x = input().split(' ')
x = [int(i) for i in x]
n, m = x[0], x[1]
a = input().split(' ')
a = [int(j) for j in a]

digui(a, 0, m, 0)
print(result)
    


#美团笔试##美团##笔经#
全部评论
太牛了
1 回复
分享
发布于 2021-09-26 08:34
多谢大佬分享😃
点赞 回复
分享
发布于 2021-09-25 18:36
联易融
校招火热招聘中
官网直投
牛逼,***一道都没出来。。。
点赞 回复
分享
发布于 2021-09-25 21:59
膜拜大佬
点赞 回复
分享
发布于 2021-09-26 20:54
有收到面试通知嘛
点赞 回复
分享
发布于 2021-09-28 09:04

相关推荐

感觉这一周太梦幻了,就像一个梦,很不真实~~~感觉这个暑期,我的运气占了99成,实力只有百分之一4.15上午&nbsp;腾讯csig&nbsp;腾讯云部门,面完秒进入复试状态4.16下午&nbsp;美团优选供应链部门,4.18上午发二面4.17晚上&nbsp;阿里国际一面,纯拷打,面完我都玉玉了4.18下午&nbsp;阿里国际二面,是我们leader面的我,很轻松~~4.18晚上&nbsp;约了hr面4.19上午&nbsp;hr面,下午两点口头oc4.19晚上&nbsp;意向书说起来我的暑期好像一次都没挂过~~~~~难道我是天生面试圣体?----------------------------------------------------------------------六个月前,我还是0项目0刷题,当时想的是先把论文发出来再去找实习。结果一次组会,老师打破了我的幻想(不让投B会,只让投刊或者A)我拿头投啊!!!然后就开始物色着找实习,顺便做完了mit的6.s081,但是基本上还是没刷过题目-----------------------------------------------------------------------11月&nbsp;&nbsp;一次偶然的机会,面进了某个耳机厂的手环部门,大概是做嵌入式的,用的是CPP。12月&nbsp;莫名其妙拿到了国创的面试机会,0基础四天速成java基础!居然也给我面过了hhhhh,可能是面试没写题吧入职国创后的几个月,一直没活,天天搁那看剧,都快忘了还有暑期实习这回事了~~~~命运的齿轮在2.26开始转动,因为这一天美团开了,我开始慌了,因为那时的我什么都不会。lc,八股,sql全部是0进度。然后就开始了女娲补天,上班刷题,下班继续做之前的开源,顺便学一学八股。3月到现在,lc也刷到快200了,一天最多提交了47次~~~~~~~~~~八股根据别人的面经总结和博客,写了快十万字的笔记~~~~~~~~~~简历上的实习经历和开源,也努力去深挖了,写了几万字的记录~~~~~~所以面试的时候,基本上都能cover了,面试官问到的基础基本都会,不基础的我就把他往我会的地方引。结果好像还不错,基本上每个面试官评价都挺好的emmmmmmmm
投递阿里巴巴等公司10个岗位
点赞 评论 收藏
转发
9 31 评论
分享
牛客网
牛客企业服务