题解 | #买卖股票的最好时机(一)#

买卖股票的最好时机(一)

http://www.nowcoder.com/practice/351b87e53d0d44928f4de9b6217d36bb

动态规划,二维 dp, 两个维度一是天数,二是持有状态; dp[i][0] 表示第 i 天未持有的最大收益, dp[i][1] 表示第 i 天持有的最大收益 转移方程为: dp[i][0] = max(dp[i - 1][0], dp[i - 1][1] + prices[i]) dp[i][1] = max(dp[i - 1[1], dp[i - 1][0] - prices[i]) 由于 k 是一次, 故 dp[i][1] = max(dp[i - 1[1], - prices[i])

import sys
n = int(sys.stdin.readline().strip())
prices = list(map(int, sys.stdin.readline().strip().split()))
dp = [[0 for _ in range(2)] for _ in range(n)]
dp[0][1] = -prices[0]
for i in range(1, n):
    dp[i][0] = max(dp[i - 1][0], dp[i - 1][1] + prices[i])
    dp[i][1] = max(dp[i - 1][1], -prices[i])

print(dp[-1][0]) 
全部评论

相关推荐

开发转测第二人:没实习的话,两个项目吧,八股也要准备一下,这个时间点有点小晚了
点赞 评论 收藏
分享
评论
2
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务