The demons had captured the princess (P) and imprisoned her in the bottom-right corner of a dungeon. The dungeon consists of M x N rooms laid out in a 2D grid. Our valiant knight (K) was initially positioned in the top-left room and must fight his way through the dungeon to rescue the princess.
The knight has an initial health point represented by a positive integer. If at any point his health point drops to 0 or below, he dies immediately.
Some of the rooms are guarded by demons, so the knight loses health (negative integers) upon entering these rooms;
other rooms are either empty (0's) or contain magic orbs that increase the knight's health (positive integers).
In order to reach the princess as quickly as possible, the knight decides to move only rightward or downward in each step.
Write a function to determine the knight's minimum initial health so that he is able to rescue the princess.
For example, given the dungeon below, the initial health of the knight must be at least 7 if he follows the optimal path RIGHT-> RIGHT -> DOWN -> DOWN.
-2 (K)
-3
3
-5
-10
1
10
30
-5 (P)
Notes:
The knight's health has no upper bound.
Any room can contain threats or power-ups, even the first room the knight enters and the bottom-right room where the princess is imprisoned.
Credits: Special thanks to @stellari for adding this problem and creating all test cases.
Seen this question in a real interview before?
Yes
No
When did you encounter this question?
last week
last month
last 3 month
last 6 month
more than 6 months
other
Which company?
Adobe
Aetion
Affirm
Airbnb
Alation
Alibaba
Amazon
AppDynamics
Apple
Arista
Baidu
Bank of America
BlackRock
Blend Labs
Blizzard
Bloomberg
Booking
Box
Bungie
Capital One
CareerBuilder
Cisco
Citadel
Coinbase
Concur
Conviva
Coupang
Coursera
CreditEase
CVTE
Dell
Deutsche Bank
DoorDash
Dropbox
Duolingo
EasyNet
eBay
Electronic Arts
EMC
Epic Systems
Equinix
Evernote
Expedia
Facebook
FactSet
Fitbit
Flipkart
Fortinet
FourSquare
FreeWheel
GoDaddy
Goldman Sachs
Google
GrabTaxi
Groupon
HBO
Hedvig
HomeAway
HTC
Huawei
Hulu
IBG
IBM
Indeed
InnovatureLabs
Intel
IXL
Jane Street
JPMorgan
Jump Trading
Lending Club
LinkedIn
LiveRamp
Loovee
Marvel
Matlab
McKesson
Microsoft
Morgan Stanley
NetEase
Nintendo
Nutanix
Nvidia
Oracle
Orbitz
Palantir
Paypal
Pinterest
Pocket Gems
Point72
Qualcomm
Qualtrics
Qumulo
Quora
Rackspace
Redfin
Rubrik
Salesforce
Samsung
SAP
ServiceNow
Sina
Snapchat
SoftwareOne
Sony
SoundHound
Square
Sumologic
SurveyMonkey
Symantec
Tableau
Tencent
Tesorio
TinyCo
Tradeshift
TripAdvisor
Twilio
Twitter
Two Sigma
Uber
Veritas
Visa
VMware
Walmart
Wealthfront
Whitepages
Works Applications
Yahoo
Yandex
Yelp
Zappos
Zenefits
Zillow
Zynga
Difficulty:Hard
Total Accepted:40.8K
Total Submissions:171.9K
Contributor:
LeetCode
Subscribe
to see which companies asked this question.