依图笔试, 求大佬指点

第一题, 交换数组递增 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

相关推荐

2025-12-12 19:01
南京航空航天大学 C++
秋招没咋投,准备&nbsp;wxg&nbsp;转正之后摆烂了。结果不堪字节&nbsp;HR&nbsp;的骚扰还是面了一下字节。之前想去字节的时候怎么面都挂。现在想着随便面一下结果三面技术面都意外顺利还有加面。十月中旬字节发了意向,wxg&nbsp;转正结果无响应。十月底字节拉了保温群,wxg&nbsp;口头通过,系统显示考核中。十一月初和字节&nbsp;ld&nbsp;交流之后得知&nbsp;base&nbsp;居然能选海外,甚至能小&nbsp;wlb&nbsp;一下,wxg&nbsp;无响应无人联系。十一月中旬把字节&nbsp;base&nbsp;转到了海外,wxg&nbsp;流程灰了,一问超时忘处理了,过两天又变考核中了。十一月下旬字节换了海外&nbsp;HR&nbsp;对接,问了期望薪资,wxg&nbsp;考核终于显示通过,无&nbsp;HR&nbsp;保温,无其他保温。十一月底给字节报了个天价,想吓吓他们,同时告诉微信字节要开了,微信无响应。同样十一月底字节&nbsp;HR&nbsp;告诉我确实给不到那么高,但是能拿期权补上,问能不能接受。微信无响应。同样十一月底字节&nbsp;HR&nbsp;告知了具体方案,符合预期。&nbsp;微信无响应。十二月上旬催&nbsp;wxg&nbsp;不开我就盲拒了,wxg&nbsp;HR&nbsp;火急火燎的打电话问情况,问期望。我给了一个不算夸张的总包数字,因为今年市场在涨,过了三天还不联系我,我再催,约时间下午打电话,非得在我给出的数字上压下去几万,微信又不差这点,为什么不能满足我,让我没有拒绝的理由呢?一番纠结抗争,求稳还是追求挑战,最终选择接受迎接新的挑战,因为堂吉诃德永远不会停下脚步!回想起来,在&nbsp;wxg&nbsp;谈薪的阶段,我认为并没有给予我一定的重视,即使&nbsp;HR&nbsp;表示我在实习期间的表现和之前的面评都很靠前。也没有感觉到想要争取我,虽然我表示拒了&nbsp;offer&nbsp;之后要给我加面委定&nbsp;t6&nbsp;再涨,但我三个月没面试让我面面委那就是白给,还是算了。有缘再见了我亲爱的&nbsp;wxg,再见了曾经的梦中情厂,再见亲爱的&nbsp;mt,再见亲爱的朋友们。也再见,北京的一切。我想润了。秋招结束,卸载牛客,下一个三年,下一个五年,下一个十年后再来看看。
面试中的大熊猫爱吃薯...:我嫉妒得狗眼通红
点赞 评论 收藏
分享
评论
点赞
5
分享

创作者周榜

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