旷视感知算法面经

项目相关问了40分钟左右,对模型的具体实现和验证非常感兴趣,论文要求详细讲解创新点,不过问的问题都比较常规,也没有问八股

手撕代码是三道题

  1. 链表中环的入口节点

快慢指针,同时从head出发,fast走两步,slow走一步,第一次相遇后把fast放到开始,步长改成1,下次相遇就是入口结点

  1. 打家劫舍2(首尾相连)
    dp[i] = max(dp[i-1], dp[i-2]+nums[i])
    dp[0] = nums[0]
    dp[1] = max(nums[:2])

首尾相连的情况下,首尾不能同时取,所以直接对nums[:n-1]和nums[1:]分别动规就行,时间复杂度是o(n),空间复杂度可以用循环数组优化成o(1)

  1. 打家劫舍3(树形结构)
    图片说明
    思路是维护一个字典,每个结点分别计算取该点的最大值和不取该点的最大值,更新的时候直接在字典里更新,最后返回root的对应的值即可。
    需要注意的是,在不取p点的时候,p->left和p->right也都有可能不取,所以在更新的时候需要用到dp[p][1]=max(dp[p.left])+max(dp[p.right])
    class Solution:
     def rob(self, root: TreeNode) -> int:
         # dp[p][0]代表取该点
         # dp[p][1]代表不取该点
         # dp[p][0] = dp[p.left][1] + dp[p.right][1]
         # dp[p][1] = max(dp[p.left])+max(dp[p.right])
         self.dp = {}
         def dfs(root):
             if root is None:
                 return
             dfs(root.left)
             dfs(root.right)
             tmp0 = root.val
             tmp1 = 0
             if root.left is not None:
                 tmp0 += self.dp[root.left][1]
                 tmp1 += max(self.dp[root.left])
             if root.right is not None:
                 tmp0 += self.dp[root.right][1]
                 tmp1 += max(self.dp[root.right])
             self.dp[root] = [tmp0,tmp1]
         dfs(root)
         return max(self.dp[root])

不太清楚旷视的上海岗位什么情况,面试完之后换了个北京的hr给我打电话说岗位调到了北京,还有两轮复试

#旷视面经#
全部评论
我投的是算法开发,上周面旷视,和你几乎一模一样,我都怀疑是同一个面试官。我在学校做的感知算法,然后就猛问感知算法的东西,题也一样,地点也是上海转北京。
2 回复 分享
发布于 2022-08-03 10:23
请问下还有后续吗?二面三面咋样呀
2 回复 分享
发布于 2022-08-24 15:11 北京
哥,想问下你这是校招还是实习?
点赞 回复 分享
发布于 2022-08-03 18:07
请问这是一面二面呀?
点赞 回复 分享
发布于 2022-08-08 21:45
楼主后续怎么样啊,我也是上海一面北京二面,二面面试官太不友好了😂
点赞 回复 分享
发布于 2022-09-19 00:37 浙江
m
点赞 回复 分享
发布于 2022-11-12 08:20 广东

相关推荐

点赞 评论 收藏
分享
评论
4
44
分享
牛客网
牛客企业服务