前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >萌新刷题(十三)买卖股票的最佳时机

萌新刷题(十三)买卖股票的最佳时机

作者头像
小歪
发布2018-04-04 14:44:11
7740
发布2018-04-04 14:44:11
举报
文章被收录于专栏:Python爬虫与算法进阶

题目

假设有一个数组,它的第i个元素是一支给定的股票在第i天的价格。如果你最多只允许完成一次交易(例如,一次买卖股票),设计一个算法来找出最大利润。

样例

给出一个数组样例 [3,2,3,1,2], 返回 1

链接 Best Time to Buy and Sell Stock、Best Time to Buy and Sell Stock

题解

最多只允许进行一次交易,显然我们只需要把波谷和波峰分别找出来就好了。但是这样的话问题又来了,有多个波峰和波谷时怎么办?——找出差值最大的一对波谷和波峰。故需要引入一个索引用于记录当前的波谷,结果即为当前索引值减去波谷的值。

Python

代码语言:javascript
复制
class Solution:
    """
    @param prices: Given an integer array
    @return: Maximum profit
    """
    def maxProfit(self, prices):
        if prices is None or len(prices) <= 1:     
                return 0

        profit = 0
        cur_price_min = 2**31 - 1
        for price in prices:
            profit = max(profit, price - cur_price_min)
            cur_price_min = min(cur_price_min, price)  
                  
        return profit

总耗时: 289 ms

在leetcode上找到的更多解法

代码语言:javascript
复制
class Solution(object):
    def maxProfit(self, prices):
        """
        :type prices: List[int]
        :rtype: int
        """
        if len(prices) == 0 or len(prices) == 1:  
            return 0

        MAX = 0

        start = prices[0]     
            
        for price in prices:    
            if price - start > MAX:
                MAX = price - start   
            if price < start :
                start = price
        
        return MAX

总耗时: 303 ms

代码语言:javascript
复制
class Solution(object):
    def maxProfit(self, prices):
        """
        :type prices: List[int]
        :rtype: int
        """
        result = 0
        for i, price in enumerate(prices):   
             if i == 0:
                low = price
            low = min(price, low)
            result = max(price-low, result)        
        return result

总耗时: 239 ms

下面是小姐姐

原来女生宿舍是这样~~

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2017-08-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Python爬虫与算法进阶 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目
  • 题解
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档