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;
        }
    };
    
  • 相关阅读:
    伸展树(SplayTree)的实现
    map的访问
    #pragma warning(disable 4786)
    debian sftp/ssh197
    debian 配置静态ip197
    deepin 安装tar.gz197
    npm构建vue项目197
    linux 常用命令197
    application/force-download 不生效197
    reids 安装197
  • 原文地址:https://www.cnblogs.com/vinnson/p/13291936.html
Copyright © 2011-2022 走看看