LeetCode122——Best Time to Buy and Sell Stock II
题目:
Say you have an array for which the ith element is the price of a given stock on day i. Design an algorithm to find the maximum profit. You may complete as many transactions as you like (i.e., buy one and sell one share of the stock multiple times). Note: You may not engage in multiple transactions at the same time (i.e., you must sell the stock before you buy again).
理解:
假设你有个数组,其中第i个元素是第i天的股票价格,请设计一种算法去找到最大的收益,你可以用任何你喜欢的方式完成交易(多次买入或卖出股票权)。
注意:你不能在同一时间完成多次交易,你必须再次买入这支股票以后才能卖出。
例子1:
Input: [7,1,5,3,6,4]
Output: 7
Explanation: Buy on day 2 (price = 1) and sell on day 3 (price = 5), profit = 5-1 = 4.
Then buy on day 4 (price = 3) and sell on day 5 (price = 6), profit = 6-3 = 3.
例子2:
Input: [1,2,3,4,5]
Output: 4
Explanation: Buy on day 1 (price = 1) and sell on day 5 (price = 5), profit = 5-1 = 4.
Note that you cannot buy on day 1, buy on day 2 and sell them later, as you are
engaging multiple transactions at the same time. You must sell before buying again.
例子3:
Input: [7,6,4,3,1]
Output: 0
Explanation: In this case, no transaction is done, i.e. max profit = 0. 原始解题思路:
要获得最好的收益,就要坚持“低吸高抛”,所以只需要比较当前日的股价与下一日的股价,如果下一日的股价高于本日,那就购买,计算收益(此时为负数),否则继续等待。
第二天继续比较第二天与第三天的股价,如果第三天高于第二天,则购买(此时相当于持有不做出操作,设置一个标志符表示当前是已买入还是已卖出),如果第三天低于第二天的股价,则卖出。 python代码:
class Solution:
def maxProfit(self, prices):
trans_flag = 0 # 0 表示未购买或者已卖出,1 表示已购买未卖出
profit = 0
end_day = len(prices)
if end_day < 2:
print("总收益:{}".format(profit))
return 0
for i in range(end_day - 1):
if prices[i] < prices[i + 1] and trans_flag == 0:
print("买入第{}天的股票".format(i + 1))
trans_flag = 1
current_i = i
profit -= prices[i]
continue
if prices[i] < prices[i + 1] and trans_flag == 1:
print("继续持有股票")
continue
if prices[i] > prices[i + 1] and trans_flag == 1:
print("卖出第{}天的股票".format(i + 1))
profit += prices[i]
current_i = 0
trans_flag = 0
continue
if prices[i] > prices[i + 1] and trans_flag == 0:
print("暂不购买")
continue
print("当前收益:{}".format(profit))
# 第一个问题:这里加一步验证一直持有到最后一天未卖出,所以收益没计算完全的问题,同时要小心很小的数据集,比如只有一个
# 第二个问题:与上一天比较时不一定要大于,可能两者相等
if prices[end_day - 1] >= prices[end_day - 2] and trans_flag == 1:
trans_flag = 1
profit += prices[end_day - 1]
print("总收益:{}".format(profit))
if __name__ == '__main__':
prices1 = [7, 1, 5, 3, 6, 4]
prices2 = [1, 2, 3, 4, 5]
prices3 = [7, 6, 4, 3, 1]
prices4 = [2,3]
prices5 = [1,9,6,9,1,7,1,1,5,9,9,9]
Mine = Solution()
Mine.maxProfit(prices5)
验证结果:
class Solution:
def maxProfit2(self, prices):
print(sum(max(prices[i + 1] - prices[i], 0) for i in range(len(prices) - 1)))
验证结果:
zip() 函数用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的对象,这样做的好处是节约了不少的内存。
我们可以使用 list() 转换来输出列表。如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同,利用 * 号操作符,可以将元组解压为列表。
>>>a = [1,2,3]
>>> b = [4,5,6]
>>> c = [4,5,6,7,8]
>>> zipped = zip(a,b) # 返回一个对象
>>> zipped
<zip object at 0x103abc288>
>>> list(zipped) # list() 转换为列表
[(1, 4), (2, 5), (3, 6)]
>>> list(zip(a,c)) # 元素个数与最短的列表一致
[(1, 4), (2, 5), (3, 6)] >>> a1, a2 = zip(*zip(a,b)) # 与 zip 相反,zip(*) 可理解为解压,返回二维矩阵式
>>> list(a1)
[1, 2, 3]
>>> list(a2)
[4, 5, 6]
>>>
在这里就是将range函数变为迭代器,每次从prices的当前位置和下一个位置取出x和y,然后依然判断求和
class Solution:
def maxProfit(self, prices):
return sum([y - x for x, y in zip(prices[:-1], prices[1:]) if x < y])
class Solution:
def maxProfit(self, prices):
return(sum(prices[i + 1] - prices[i] for i in range(len(prices) - 1) if prices[i + 1] > prices[i]))
结果:
所以想提高,还是要学一下迭代器的应用啊。
LeetCode122——Best Time to Buy and Sell Stock II的更多相关文章
- Leetcode-122 Best Time to Buy and Sell Stock II
#122 Best Time to Buy and Sell Stock II Say you have an array for which the ith element is the pric ...
- LeetCode122:Best Time to Buy and Sell Stock II
题目: Say you have an array for which the ith element is the price of a given stock on day i. Design a ...
- [LintCode] Best Time to Buy and Sell Stock II 买股票的最佳时间之二
Say you have an array for which the ith element is the price of a given stock on day i. Design an al ...
- LEETCODE —— Best Time to Buy and Sell Stock II [贪心算法]
Best Time to Buy and Sell Stock II Say you have an array for which the ith element is the price of a ...
- 27. Best Time to Buy and Sell Stock && Best Time to Buy and Sell Stock II && Best Time to Buy and Sell Stock III
Best Time to Buy and Sell Stock (onlineJudge: https://oj.leetcode.com/problems/best-time-to-buy-and- ...
- 【leetcode】Best Time to Buy and Sell Stock II
Best Time to Buy and Sell Stock II Say you have an array for which the ith element is the price of a ...
- 31. leetcode 122. Best Time to Buy and Sell Stock II
122. Best Time to Buy and Sell Stock II Say you have an array for which the ith element is the price ...
- LeetCode: Best Time to Buy and Sell Stock II 解题报告
Best Time to Buy and Sell Stock IIQuestion SolutionSay you have an array for which the ith element i ...
- Algorithm - 贪心算法使用场景 ( LEETCODE —— Best Time to Buy and Sell Stock II)
先看一道leetcode题: Best Time to Buy and Sell Stock II Say you have an array for which the ith element is ...
随机推荐
- AMD vs. CommonJS?
js开发者对js模块加载的尝试和创新从来都没有停止过,尤其是当nodejs的出现后,模块化加载的必要性更加凸显.本文不讨论如何在nodejs环境来模块化加载(创造者已经利用commonJS机制解决), ...
- Exceptionless 5.0.0 本地Docker快速部署介绍
在之前我有专门写两篇文章介绍过Exceptionless这款开源日志项目的使用和部署,但是当时是基于4.1.0版本(2017年的release),时隔两年多Exceptionless也推出了5.0.0 ...
- js 判断字符串是否存在某个字符串
可使用String和Regexp对象的相关方法进行处理,如下 一.String对象方法 1.使用indexOf()方法,返回某个指定的字符串值在字符串中首次出现的位置.如果要检索的字符串值没有出现,则 ...
- 什么是VR中的Locomotion?
Locomotion,本文中我称之为移位,是VR研究中最重要的话题之一.因为它属于VR中三大元老级操作(Selection选择,Manipulation操纵物体,Locomotion移位),其中,前两 ...
- git 查看日志记录
1.git log 如果日志特别多的话,在git bash中,按向下键来查看更多,按q键退出查看日志. 2.git show 查看最近一次commit内容,也可以后面加commit号,单独查看此次版本 ...
- git 工作流中的 Sourcetree 和命令行操作对比
git 工作流操作 1.初始化本地仓库文件夹 终端进入项目文件夹 git init 隐藏文件夹中有 .git 文件夹则初始化成功 2.git 查看仓库状态 这里以新建一个 demo.txt 为例 ① ...
- 4、pytest 中文文档--pytest-fixtures:明确的、模块化的和可扩展的
目录 1. fixture:作为形参使用 2. fixture:一个典型的依赖注入的实践 3. conftest.py:共享fixture实例 4. 共享测试数据 5. 作用域:在跨类的.模块的或整个 ...
- python获取全国各个城市pm2.5、臭氧等空气质量
随着国家发展,中国很多城市的空气质量其实并不好,国家气象局会有实时统计,但是要去写爬虫爬取是十分麻烦的事情,并且官方网站也会做一些反爬虫措施,所以实现起来比较麻烦,最好的办法就是使用现成的免费接口,空 ...
- Python PDB调试处理
pdb 是 python 自带的一个包,为 python 程序提供了一种交互的源代码调试功能,主要特性包括设置断点.单步调试.进入函数调试.查看当前代码.查看栈片段.动态改变变量的值等.pdb 提供了 ...
- 01 python安装与初识
一.简要概述 python学习时设计要大于开发. 二.编程语言 1.分类 编程语言分为高级语言和低级语言.高级语言如python.c#,Java.PHP等,低级语言(基础语言)如C.汇编语言. 2.机 ...