依图笔试, 求大佬指点

第一题, 交换数组递增 10%
'''
@Author: rayenwang
@LastEditTime: 2019-09-06 20:40:27
@Description: 
'''
N = int(input())
nums = [int(n) for n in input().split()]

# N = 5
# nums = [1, 5, 2, 4, 3]
result = 0
for i in range(N):
    if nums[i] == i + 1:
        continue
    index = nums[i] - 1
    nums[i], nums[index] = nums[index], nums[i]
    result += 1
print(result)
第二题, 粉碎我自己 AC
'''
@Author: rayenwang
@LastEditTime: 2019-09-06 20:01:39
@Description: 
'''


def fill(height, space, index, N):
    pre_sum = 0
    for i in range(index, N):
        if pre_sum + height[i] <= space:
            pre_sum += height[i]
        else:
            return False, i, space - pre_sum
    return True, i, space - pre_sum


import math
N, H, K = [int(n) for n in input().split()]
height = []
for _ in range(N):
    height.append(int(input()))
# N, H, K = [5, 5, 3]
# height = [5, 4, 3, 2, 1]

time = 0
finish, index, space = fill(height, H, 0, N)
if finish:
    print(math.ceil((H - space) / K))
else:
    while index < N:
        wait = math.ceil((height[index] - space) / K)
        time += wait
        space = min(H, space + wait * K)
        finish, index, space = fill(height, space, index, N)
        if finish:
            break
    print(time + math.ceil((H - space) / K))
第三题, 最大的K个节点之和 0%
'''
@Author: rayenwang
@LastEditTime: 2019-09-06 20:33:16
@Description: 
'''

N, K, S = [int(n) for n in input().split()]
path = [[] for _ in range(N + 1)]
for _ in range(N - 1):
    x, y = [int(n) for n in input().split()]
    path[x].append(y)
value = [0]
for _ in range(N):
    value.append(int(input()))
result = [0 for _ in range(N + 1)]


def recur(root):
    if not root:
        return []
    temp = [root]
    for child in path[root]:
        temp = sorted(temp + recur(child), reverse=True)[:K]
    result[root] = sum(temp)
    return temp


recur(S)
for i in range(1, N + 1):
    print(result[i])
    



#笔试题目##依图科技#
全部评论
这是第三套卷子,楼主第一题题目应该没说数组是连续的吧,直接index = num[i]-1是不对吧
点赞 回复 分享
发布于 2019-09-06 21:33
第一题这个思路对吗?AC了?
点赞 回复 分享
发布于 2019-09-07 14:38
# coding=utf-8 import sys if __name__ == "__main__":     nhk = sys.stdin.readline().strip().split()     n = int(nhk[0])     h = int(nhk[1])  # kerongna     k = int(nhk[2])  # meimiao     a = []     for _ in range(n):         a.append(int(sys.stdin.readline().strip()))     temp = 0     i = 0     res = 0     while i < n or temp > 0:         if i < n and temp + a[i] <= h:             temp += a[i]             i += 1         temp = max(temp-k, 0)         res += 1     print(res) 求问第二题,哪里没考虑全😭,按照粉碎的过程
点赞 回复 分享
发布于 2019-09-07 00:42
第一题没有说是1~N吧,数组是随意给的
点赞 回复 分享
发布于 2019-09-07 00:34
"""依图笔试第三套第一题,数组交换""" import sys n = int(input()) nums = list(map(int,input().split())) dicts = {} sort_nums = sorted(nums) for i in range(len(sort_nums)):     dicts[sort_nums[i]] = i cnt = 0 flag = [False]*len(nums) for i in range(len(nums)):     if not flag[i]:         j = i         while not flag[j]:             flag[j] = True             j = dicts[nums[j]]         cnt += 1 print(len(nums) - cnt)
点赞 回复 分享
发布于 2019-09-06 23:21
交换数组  #!/usr/bin/env python # encoding: utf-8 import sys n = int(sys.stdin.readline().strip()) nums = map(int, sys.stdin.readline().strip().split(' ')) nums = [0] + nums Flag = True count = 0 while Flag:     Flag = False     for i in range(1, n+1):         if nums[i] != i:             # print nums[i]             tmp = nums[nums[i]]             nums[nums[i]] = nums[i]             nums[i] = tmp             count += 1             Flag = True print count
点赞 回复 分享
发布于 2019-09-06 21:54
第一道ac 第二道80% 后面两道怎么搞都是0 很绝望
点赞 回复 分享
发布于 2019-09-06 21:53
第二题粉碎50% 超时。。。。感觉复杂度不高啊 #!/usr/bin/env python # encoding: utf-8 import sys import math n, h, k = map(int, sys.stdin.readline().strip().split(' ')) a = [] for i in range(n):     tmp = int(sys.stdin.readline().strip())     a.append(tmp) total_time = 0 tmp = a.pop(0) rem = h - tmp is_empty = False Flag = True while a:     Flag = False     # print a     tmp = a.pop(0)     while rem >= tmp:         rem = rem - tmp         if a:             tmp = a.pop(0)         else:             is_empty = True             break     if is_empty:         total_time += int(math.ceil((h-rem)*1./k))     else:         tmp_time = int(math.ceil((tmp - rem)*1. / k))         # print rem, tmp         # print tmp_time         # break         rem = min(tmp_time * k + rem, h)         total_time += tmp_time         a = [tmp] + a if Flag:     total_time = int(math.ceil(tmp*1./k)) print total_time
点赞 回复 分享
发布于 2019-09-06 21:52
#!/usr/bin/env python # encoding: utf-8 import sys def sub_k(s):     max_k = 0     for i in range(10, -1, -1):         Flag = True         for j in range(2**i-1, -1, -1):             tmp = bin(j)[2:]             for k in range(i-len(tmp)):                 tmp = '0'+tmp             if tmp not in s:                 Flag = False                 break         if Flag:             max_k = i             break     return max_k n, m = map(int, sys.stdin.readline().strip().split(' ')) string = ['-1'] for i in range(n):     tmp_str = sys.stdin.readline().strip()     string.append(tmp_str) op = [[i] for i in range(n+1)] for i in range(m):     left, right = map(int, sys.stdin.readline().strip().split(' '))     op.append(op[left]+op[right]) concat = [] for l in op[n+1:]:     # tmp_str = string[left] + string[right]     tmp_str = ''.join([string[i] for i in l])     string.append(tmp_str)     # print tmp_str     print sub_k(tmp_str) 第四题 80%
点赞 回复 分享
发布于 2019-09-06 21:50
第四题呢。。
点赞 回复 分享
发布于 2019-09-06 21:45
第三题并不是前面的就是父节点 你需要自己判断; 第一题: 借鉴LeetCode的41题的思想https://leetcode.com/problems/first-missing-positive/ def change(arr):     res=0     for i in range(len(arr)):         while (arr[i]!=arr[arr[i]]):             res+=1             arr[arr[i]],arr[i]=arr[i],arr[arr[i]]     return res def p1():     n=int(input())     arr=[int(i) for i in input().split()]     ind=sorted(range(n),key=lambda x:arr[x]) # 返回index     print(change(ind))
点赞 回复 分享
发布于 2019-09-06 21:32
这是哪套题?
点赞 回复 分享
发布于 2019-09-06 21:25
第二题需要考虑什么边界么,只做了80%
点赞 回复 分享
发布于 2019-09-06 21:18
同求大佬
点赞 回复 分享
发布于 2019-09-06 21:15

相关推荐

07-25 11:26
清华大学 Java
打开电脑,思绪又回到了7月份刚开始的时候,感觉这个月过的如梦如幻,发生了太多事,也算是丰富了我本就是平淡的人生吧太早独立的我习惯了一切都是自己做决定,拥有绝对的决定权,而且永远不会听取别人的建议。我就是那个恋爱四年出轨的男主啦,感觉既然在牛客开了这个头,那我就要做个有始有终的人。从我出轨到结束再到和女朋友和好如初真的太像一场梦了,短短的一个月我经历了太多,也成长了很多,放下了那些本就不属于我的,找回了那些我不该放弃的。我的人生丰富且多彩,但人不能一直顺,上天总会让你的生活中出点乱子,有好有坏,让你学会一些东西,让你有成长。我和女朋友的恋爱四年太过于平淡,日常除了会制造一些小浪漫之外,我们的生活...
段哥亡命职场:不得不说,我是理解你的,你能发出来足见你是个坦诚的人,至少敢于直面自己的内心和过往的过错。 这个世界没有想象中那样非黑即白,无论是农村还是城市,在看不见的阴影里,多的是这样的事。 更多的人选择站在制高点去谩骂,一方面是社会的道德是需要制高点的,另一方面,很多人不经他人苦,却劝他人善。 大部分的我们,连自己生命的意义尚且不能明晰,道德、法律、困境,众多因果交织,人会迷失在其中,只有真的走出来之后才能看明白,可是没走出来的时候呢?谁又能保证自己能走的好,走的对呢? 可是这种问题有些人是遇不到的,不去追寻,不去探寻,也就没了这些烦恼,我总说人生的意义在过程里,没了目标也就没了过程。 限于篇幅,没法完全言明,总之,这世界是个巨大的草台班子,没什么过不去了,勇敢面对,革故鼎新才是正确,祝你早日走出来。查看图片
点赞 评论 收藏
分享
人力小鱼姐:实习经历没有什么含金量,咖啡店员迎宾这种就别写了,其他两段包装一下 想找人力相关的话,总结一下个人优势,结合校园经历里有相关性的部分,加一段自我评价
点赞 评论 收藏
分享
05-30 12:03
山西大学 C++
offer来了我跪着...:不是骗子,等到测评那一步就知道为啥这么高工资了
点赞 评论 收藏
分享
评论
点赞
5
分享

创作者周榜

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