zoukankan      html  css  js  c++  java
  • 【刷题-LeetCode】121 Best Time to Buy and Sell Stock

    1. Best Time to Buy and Sell Stock

    Say you have an array for which the ith element is the price of a given stock on day i.

    If you were only permitted to complete at most one transaction (i.e., buy one and sell one share of the stock), design an algorithm to find the maximum profit.

    Note that you cannot sell a stock before you buy one.

    Example 1:

    Input: [7,1,5,3,6,4]
    Output: 5
    Explanation: Buy on day 2 (price = 1) and sell on day 5 (price = 6), profit = 6-1 = 5.
                 Not 7-1 = 6, as selling price needs to be larger than buying price.
    

    Example 2:

    Input: [7,6,4,3,1]
    Output: 0
    Explanation: In this case, no transaction is done, i.e. max profit = 0.
    

    解法1 暴力求解,计算出(max_{i < j} {prices[j] - prices[i]})

    解法2 one-pass。在全局最低点买入,卖出一定在该点之后,因此一边寻找min_p,一边计算max_profit

    class Solution {
    public:
        int maxProfit(vector<int>& prices) {
            int n = prices.size();
            int profit = 0;
            int min_p = INT_MAX;
            for(int i = 0; i < n; ++i){
                if(prices[i] < min_p)min_p = prices[i];
                profit = max(profit, prices[i] - min_p);
            }
            return profit;
        }
    };
    
  • 相关阅读:
    poj 2251 Dungeon Master
    poj 2488 A Knight's Journey
    poj 3349
    poj 2442
    poj 3274 Gold Balanced Lineup
    优先队列
    广州华盟信息科技有限公司
    山东山大华天软件有限公司
    RvmTranslator6.5 is released
    PipeCAD之管道标准库PipeStd(2)
  • 原文地址:https://www.cnblogs.com/vinnson/p/13291936.html
Copyright © 2011-2022 走看看