prices๋ ๋ฐฐ์ด์ด๋ฉฐ, ๊ฐ ์์๋ ๋งค์ผ์ ์ฃผ์ ๊ฐ๊ฒฉ์ ๋๋ค.
๋ง์ฝ ํ ๋ฒ๋ง ๊ฑฐ๋ํ ์ ์๋ค๋ฉด = ์ฌ๊ณ ํ ์ ์๋ค๋ฉด, ์ ์ผ ํฐ ์ด์ต์ ์ผ๋ง์ผ๊น์?
- ์๋ฅผ ๋ค์ด,
Input: [7,1,5,3,6,4] Output: 5
2์ผ(๊ฐ๊ฒฉ=1)์ ์๋ค๊ฐ 5์ผ(๊ฐ๊ฒฉ=6)์ ์ฌ๋ ๊ฒ์ด 6-1์ด๋ผ ์ ์ผ ํฐ ์์ต
7-1=6 ์ ์ ๋๋๊ฑฐ ์์์ฃ ? ๋จผ์ ์ฌ์ผ ํ ์ ์์ต๋๋ค.Input: [7,6,4,3,1] Output: 0
์ฌ๊ธฐ์๋ ๋งค์ผ ๊ฐ๊ฒฉ์ด ๋ฎ์์ง๊ธฐ ๋๋ฌธ์ ๊ฑฐ๋๊ฐ ์์ต๋๋ค. ๊ทธ๋์ 0
๊ฐ์๋ก ์์ค์ด ๋์์ง๋ ์ฝ๋์นดํ!
๊ณ์ํด์ ์ด์ด์ง๋,, ์
์ฒด์ ์ผ๋ก ์๊ฐํด์ผ ํ๋ ๋ฌธ์ ๋ค์ ์ฐ์์ ๋งฅ์์ด ์ฐ๋ฌ์ง๋ ๊ฒ ๊ฐ๋ค
๋ฌผ๋ก ํ๋ก์ ํธ ๋๋ฌธ์ ์์ ์ฝ๋์นดํ๋ฅผ ํ ์๋๋ ์ฌ์ ๋ ์๊ธด ํ์ง๋ง..
prices๋ฐฐ์ด์ for loop
์ผ๋ก ๋๋ฆฌ๋ฉด์ ๊ฐ ๊ฒฝ์ฐ๋ง๋ค ์ด๋ค ์์ต์ด ๋ ์ง ํ์ธํด? ์ด๊ฒ ๋ง์ด ๋ผ..?
๊ทธ๋ผ.. ๊ฒฝ์ฐ์ ์๊ฐ.... 36๊ฐ์ผ..? ๋ง๋..?
def maxProfit(prices):
max_profit, min_price = 0, float('inf')
for price in prices:
min_price = min(min_price, price)
profit = price - min_price
max_profit = max(max_profit, profit)
return max_profit
์ ์ญ์๋ ์ค๋๋ float('inf')
๊ฐ ๋ฌด์์ธ์ง ๋ชจ๋ฅด๋ ๋..!!!
์ฒ์์ int
๋ฅผ ์คํ๋ธ ์ค ์์๋๋ฐ ์ ๊ฒ ์ง์ง ๋ง๋ ์ฝ๋์๋ค. (์ถฉ๊ฒฉ)
์ญ์ ์ธ์์ ๋๊ณ ์ฝ๋๋ ๋ง์
It acts as an unbounded upper value for comparison. This is useful for finding lowest values for something.
for example, calculating path route costs when traversing trees.
ํ๋ง๋๋ก ์ง๊ธ๊ณผ ๊ฐ์ ๋ฌธ์ ์ํฉ์์, ๊ฐ์ฅ ๊ฐ์ด ์ ๊ฒ ๋์ค๋ ๊ฒฝ์ฐ๋ฅผ ์ฐพ์ ์ ์๋ ํจ์!
๐๐ป What is the point of float('inf')?
Finding the "cheapest" path in a list of options: (์ฐ๋ฆฌ ๋ฌธ์ ๋ ๋น์ทํ๋ค)
>>> lowest_path_cost = float('inf')
>>> # pretend that these were calculated using some worthwhile algorithm
>>> path_costs = [1, 100, 2000000000000, 50]
>>> for path in path_costs:
... if path < lowest_path_cost:
... lowest_path_cost = path
...
>>> lowest_path_cost
1
It acts as an unbounded upper value for comparison. This is useful for finding lowest values for something. for example, calculating path route costs when traversing trees.
if you didn't have float('Inf') available to you, what value would you use for the initial lowest_path_cost? Would 9999999 be enough -- float('Inf') removes this guesswork.