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;
        }
    };
    
  • 相关阅读:
    Pytorch笔记
    Anaconda使用
    最大流最小割算法
    pycallgraph--使用pycallgraph绘制Python函数调用关系图
    论文表格--三线表
    0514数据结构--递归、排序和查找
    0511操作系统
    0510操作系统
    ACWING算法提高课-动态规划
    删括号
  • 原文地址:https://www.cnblogs.com/vinnson/p/13291936.html
Copyright © 2011-2022 走看看