腾讯笔试,综合后台 100-100-0-100-20

1 电话 ac
import sys

t = int(sys.stdin.readline().strip())

for _ in range(t):
    n = int(sys.stdin.readline().strip())
    line = sys.stdin.readline().strip()
    if n < 11:
        print('NO')
        continue
    else:
        for c in line:
            if n < 11:
                print('NO')
                break
            if c == '8':
                print('YES')
                break
            else:
                n -= 1
2 配对 ac
import sys

t = int(sys.stdin.readline().strip())
time_list = []
time_dict = {}

for _ in range(t):
    line = sys.stdin.readline().strip()
    nlist = list(map(int, line.split()))
    n = nlist[0]
    time = nlist[1]
    time_list.append(time)
    time_dict[time] = n

time_list.sort()
i = 0
j = len(time_list) - 1
max_sum = 0
while i < j:
    curr_sum = time_list[i] + time_list[j]
    max_sum = max(curr_sum, max_sum)
    if time_dict[time_list[i]] < time_dict[time_list[j]]:
        time_dict[time_list[j]] -= time_dict[time_list[i]]
        i += 1
    elif time_dict[time_list[i]] > time_dict[time_list[j]]:
        time_dict[time_list[i]] -= time_dict[time_list[j]]
        j -= 1
    else:
        i += 1
        j -= 1
print(max_sum)
3 0 https://zhuanlan.zhihu.com/p/20038650 maybe this?
4 减去最小数 ac
import sys

line = sys.stdin.readline().strip()
nlist = list(map(int, line.split()))
n = nlist[0]
k = nlist[1]

line = sys.stdin.readline().strip()
nlist = list(map(int, line.split()))

nlist.sort()

res = 0
i = 0
for _ in range(k):
    if i > n - 1:
        print(0)
    else:
        while nlist[i] - res <= 0:
            i += 1
            if i > n - 1:
                break
        if i <= n - 1:
            print(nlist[i] - res)
            res += nlist[i] - res
            i += 1
        else:
            print(0)
5 异或 20% 就不插代码了,后来有思路没时间了。
#腾讯##笔试题目#
全部评论
第三题竟然A了,我也是醉了 num = int(input()) list1 = list(map(int, input().strip().split())) list1.sort() list1.reverse() list2 = [] signal = 0 for i in list1:     if signal == 0:         list2.append(str(i))         signal = 1     else:         list2.insert(0, str(i))         signal = 0 str1 = " ".join(list2) print(str1)
点赞 回复 分享
发布于 2019-09-20 22:41
第一题我不懂为什么就是过不了 num = int(input()) signal = 0 for i in range(num):     n = int(input())     str = input()     if n < 11:         print("NO")     else:         for i in range(n - 10):             if str[i] == "8":                 print("YES")                 signal = 1                 break         if signal == 0:             print("NO")
点赞 回复 分享
发布于 2019-09-20 22:40
第三题我就是三维背包啊,过不了……就30%,我都想了半天有没有其他思路了
点赞 回复 分享
发布于 2019-09-20 22:21
同3.2
点赞 回复 分享
发布于 2019-09-20 22:09
第三题背包做的不懂为啥结果 10%
点赞 回复 分享
发布于 2019-09-20 22:08
最后一题 思路是啥啊 兄弟
点赞 回复 分享
发布于 2019-09-20 22:06

相关推荐

点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
今天 12:11
我最近都有点不想活了,天天早10晚11的,还问我爱不爱她目前的状态别说爱谁了,没扇谁就不错了。是不是大家都是一进节子,只有工作没有爱情了
AzureSkies:在字节的时候找的就是字节的,飞书太适合恋爱人士了,能看到是不是已读,是不是在会议中。简直冥婚好伴侣
投递字节跳动等公司9个岗位
点赞 评论 收藏
分享
评论
1
13
分享

创作者周榜

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