I recently tackled a classic LeetCode problem: "Best Time to Buy and Sell Stock." This problem asks you to find the maximum profit you can make by buying and selling a stock once. Let's dive into the different approaches I explored, along with their complexities. Here's the URL of the problem:
LeetCode 121
The most straightforward solution might be to compare every element in the array with all the remaining elements. For each price, we calculate the profit it would generate if sold on a later day. We then keep track of the maximum profit encountered. This approach, however, suffers from high time complexity and resulted in Time Limit Exceeded.
/** * @param {number[]} prices * @return {number} */ var maxProfit = function (prices) { let max = 0; for (var i = 0; i a) return b - a; else return 0; }
Here's why: We compare each element with n-1 other elements, resulting in n*(n-1)/2 comparisons. This translates roughly to O(n^2) time complexity, which becomes inefficient for large datasets. Unfortunately, this approach often leads to a "Time Limit Exceeded" error on LeetCode.
To improve efficiency, we can leverage the fact that we're buying before selling. We can introduce two pointers:
The idea is to iterate through the prices array, starting from the third element (since the first two elements are used for buying and selling). We continuously check if the difference between the sell price (current element) and the buy price is greater than the current maximum profit. If true, we update the maximum profit. Otherwise, we update the buy pointer to the current element (potentially a lower buying price) and move the sell pointer one step forward.
This approach offers a significant improvement in time complexity, reaching O(n) as we only iterate through the array once.
/** * @param {number[]} prices * @return {number} */ var maxProfit = function (prices) { let maxProfit = 0; let buy = 0; let sell = 1; while (sell <p><img src="https://img.php.cn/upload/article/000/000/000/172284027594031.png" alt="LeetCode Problem : Best Time to Buy and Sell Stock" loading="lazy" style="max-width:90%" style="max-width:90%"></p> <h2> LeetCode Problem : Best Time to Buy and Sell Stock Approach (Time Complexity: O(n)) with Python Example </h2> <p>We can achieve a similar time complexity with a greedy approach. The key here is to understand that the maximum profit can only be achieved if we buy low and sell high. Therefore, we can iterate through the price array and keep track of the minimum price encountered so far. This represents the potential buying price.</p> <p>Here's a Python implementation of the greedy approach:<br> </p> <pre class="brush:php;toolbar:false">class Solution: def maxProfit(self, prices: List[int]) -> int: max_profit = 0; min_buy = float('inf') for price in prices: min_buy = min(min_buy , price ) max_profit = max(max_profit, price-min_buy) return max_profit
You can always learn more about where else to find me on my portfolio here
The above is the detailed content of LeetCode Problem : Best Time to Buy and Sell Stock. For more information, please follow other related articles on the PHP Chinese website!