<
回复: 6
收起左侧

oracle 店面

匿名用户-2E0Q6  2024-6-18 00:02:20 来自APP
本楼:   👍  0
0%
0%
0   👎

2024(4-6月) 码农类General 硕士 全职@oracle - 内推 - 技术电面  | 🙁 Negative 😣 HardFail | 在职跳槽

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
4月份oracle店面,感觉是dp问题,但是不知道怎么用dp做,求大家指点一下

[/hide=100]In a game machine, there is a vertical stack of layers. A ball dropped into a layer from a hole in each layer loses some kinetic energy as it passes through each layer. The energy required to pass through each layer is provided to you as a list. Each layer also has reward points, which can be positive or negative. If the ball passes through the layer, the reward points are either added or subtracted from your total. If the ball has insufficient energy to pass through the layer, you do not receive that layer's reward points and the game ends with your existing points. Find the best layer to drop the ball that maximizes reward points.

Problem Statement
You are given two arrays: energyCosts and points, and an integer initialEnergy.

energyCosts[i] represents the energy required to move from position i to i+1.
points[i] represents the points you earn at position i, could be positive or nega
您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
使用VIP即刻解锁阅读权限或查看其他获取积分的方式
游客,您好!
本帖隐藏的内容需要积分高于 188 才可浏览
您当前积分为 0。
VIP即刻解锁阅读权限查看其他获取积分的方式
消耗一定的动能energyCosts[i],每过一层可以得到reward points,可以是正point也可以是负point, 问从哪一层开始扔小球, 可以使小球消耗完动能获得的点数最大

输入:energyCosts array和rewardPoints array,以及一个正整数动能initialEnergy。
energyCosts[i]表示从层i移动到层i+1所需的动能,全是正数
points[i]表示你在位置i可获得的点数,可能是正数或负数。
输出:可以获得最大分数的起始层

评分

参与人数 2大米 +6 收起 理由
ryanking + 1 欢迎分享你知道的情况,会给更多积分奖励!
清道神君 + 5 欢迎分享你知道的情况,会给更多大米奖励!

查看全部评分


上一篇:Five Rings 技术电面1-3轮面经
下一篇:beaconfire java full stack7月面经
liuxu2024 2024-6-18 03:10:32 | 显示全部楼层
本楼:   👍  0
0%
0%
0   👎
全局:   55
100%
0%
0
sliding window
回复

使用道具 举报

地里匿名用户
匿名用户-2E0Q6  2024-6-18 04:31:37
本楼:   👍  0
0%
0%
0   👎

这题目有一点是每次移动得到的rewarding points是可以有正有负的,sliding window的window怎么保证一定是最大的points
扫码关注一亩三分地求职移民公众号
更多干货内容等你发现
回复

使用道具 举报

地里匿名用户
匿名用户-2E0Q6  2024-6-18 05:24:31
本楼:   👍  0
0%
0%
0   👎

明白了,感谢🙏
回复

使用道具 举报

地里匿名用户
匿名用户-2E0Q6  2024-6-18 07:18:32
本楼:   👍  0
0%
0%
0   👎

  1. class BallFalling:
  2.     def best_place_to_start_dropping(self, initial_energy: int, energy_cost: list[int], reward_points: list[int]) -> int:
  3.         n = len(energy_cost)
  4.         prefix_rewards = [0 for i in range(n + 1)]
  5.         prefix_rewards[1] = reward_points[0]
  6.         for i in range(2, n + 1):
  7.             prefix_rewards[i] = prefix_rewards[i - 1] + reward_points[i - 1]
  8.         
  9.         l, r = 0, 0
  10.         rewards_sum = -float('inf')
  11.         target_idx = -1
  12.         energy_cost_sum = 0
  13.         while l < n or r < n:
  14.             while l < n and l == r and energy_cost[l] > initial_energy:
  15.                 l += 1
  16.                 r += 1

  17.             if l == n:
  18.                 break

  19.             while r < n and energy_cost_sum + energy_cost[r] <= initial_energy:
  20.                 energy_cost_sum += energy_cost[r]
  21.                 r += 1

  22.             # calculate rewards
  23.             rewards_at_cur_window = prefix_rewards[r] - prefix_rewards[l]
  24.             if rewards_at_cur_window > rewards_sum:
  25.                 rewards_sum = rewards_at_cur_window
  26.                 target_idx = l
  27.             
  28.             energy_cost_sum -= energy_cost[l]
  29.             l += 1
  30.         
  31.         return (target_idx, rewards_sum)


  32. s = BallFalling()
  33. # print(s.best_place_to_start_dropping(1, [2, 2, 2, 1, 3, 4, 2, 1, 2], [-2, 1, 3, 4, -1, 2, 1, -5, 4]))
  34. print(s.best_place_to_start_dropping(2, [2, 2, 2, 100], [-2, 1, 3, 4]))
复制代码
发一个自己写的双指针的解法
回复

使用道具 举报

浪仔 2024-6-19 08:17:00 | 显示全部楼层
本楼:   👍  0
0%
0%
0   👎
全局:   0
0%
100%
2
你好 请问oracle从投简历到拿点面的timeline可以share一下吗, 谢谢!
回复

使用道具 举报

地里匿名用户
匿名用户-2E0Q6  2024-6-19 10:07:12 来自APP
本楼:   👍  0
0%
0%
0   👎
本帖最后由 匿名 于 2024-6-18 21:09 编辑
浪仔 发表于 2024-06-18 17:17:00
你好 请问oracle从投简历到拿点面的timeline可以share一下吗, 谢谢!

记不太清具体时间了,应该隔了一个月的时间才有hr联系我
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

Advertisement
>
快速回复 返回顶部 返回列表