【力扣】188. 买卖股票的最佳时机 IV
给定一个整数数组 prices ,它的第 i 个元素 prices[i] 是一支给定的股票在第 i 天的价格。
设计一个算法来计算你所能获取的最大利润。你最多可以完成 k 笔交易。
注意:你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。
示例 1:
输入:k = 2, prices = [2,4,1]
输出:2
解释:在第 1 天 (股票价格 = 2) 的时候买入,在第 2 天 (股票价格 = 4) 的时候卖出,这笔交易所能获得利润 = 4-2 = 2 。
示例 2:输入:k = 2, prices = [3,2,6,5,0,3]
输出:7
解释:在第 2 天 (股票价格 = 2) 的时候买入,在第 3 天 (股票价格 = 6) 的时候卖出, 这笔交易所能获得利润 = 6-2 = 4 。
随后,在第 5 天 (股票价格 = 0) 的时候买入,在第 6 天 (股票价格 = 3) 的时候卖出, 这笔交易所能获得利润 = 3-0 = 3 。提示:
0 <= k <= 100
0 <= prices.length <= 1000
0 <= prices[i] <= 1000来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/best-time-to-buy-and-sell-stock-iv
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
// 时间复杂度 O(n * k)把从1 到 k的所有交易笔数的最大价格都求出来
// 空间复杂度 O(n * k)
public int maxProfit(int k, int[] prices) { //之前的算法是指定交易笔数,一笔或者两笔
//那么当交易笔数变为非固定值时:应该怎么做呢?
//想法也很简单,我们可以求出来固定交易笔数的最大的价格,当然也可以把从1 到 k的所有交易笔数的最大价格都求出来
int length = prices.length; if(length < 2 || k < 1){
return 0;
}
//想想最多有几次交易的机会 要么是长度的1/2 要么是k
k = Math.min(length / 2,k);
int [][] sell = new int[length][k+1];
int [][] buy = new int[length][k+1]; //设置初始值
//首先是第一天买不买
buy[0][0] = -prices[0];
sell[0][0] = 0;
//那像buy[0][2] 这种情况怎么处理呢? 第一天开始的时候,还不能交易2笔
//sell[0][2]同理
for(int i = 1; i <= k; i++){
buy[0][i] = Integer.MIN_VALUE / 2;
sell[0][i] = Integer.MIN_VALUE / 2;
}
//现在还剩下buy[i][0]这种怎么处理?需要放到循环里处理,为什么要放到循环里,因为他也需要取最小值,看看几天一次交易也没有,哪个金额最小 //举例:
//sell[1][1] = Math.max(buy[i-1][j-1]+prices[i],sell[i-1][j]); //外层循环就是第几天
for(int i = 1; i < length; i++){
buy[i][0] = Math.max(buy[i - 1][0], sell[i - 1][0] - prices[i]); //内层循环就是交易笔数了
for(int j = 1; j <= k ; j++){
//假设,到今天已经售卖了第j笔了
//有可能昨天买的,今天卖出 之前交易j-1笔,买卖完成才算一笔
//有可能之前售卖的笔数已经够j笔了
sell[i][j] = Math.max(buy[i-1][j-1] + prices[i],sell[i-1][j]); // 假设今天已经交易了j笔了
//有可能昨天已经交易j笔了
//有可能昨天已经卖出了j笔,今天买入
buy[i][j] = Math.max(sell[i-1][j] - prices[i],buy[i-1][j]);
}
}
Arrays.sort(sell[length-1]);
return sell[length-1][k];
}
public int maxProfit(int k, int[] prices) {
// 时间复杂度 O(n * k)把从1 到 k的所有交易笔数的最大价格都求出来
// 空间复杂度 O(k) //如何尽可能的压缩空间
int length = prices.length;
if(length < 2 || k < 1){
return 0;
}
k = Math.min(length / 2,k);
int [] sell = new int[k+1];
int [] buy = new int[k+1];
//设置初始值
//首先是第一天买不买 ,不管第几天买,都是-prices[0]
sell[0] = 0;
Arrays.fill(buy,-prices[0]);
//外层循环就是第几天
for(int i = 1; i < length; i++){
//内层循环就是交易笔数了
for(int j = 1; j <= k ; j++){
sell[j] = Math.max(buy[j] + prices[i],sell[j]); //卖出
buy[j] = Math.max(sell[j-1] - prices[i],buy[j]); //买入
}
}
return sell[k];
}
【力扣】188. 买卖股票的最佳时机 IV的更多相关文章
- Leetcode之动态规划(DP)专题-188. 买卖股票的最佳时机 IV(Best Time to Buy and Sell Stock IV)
Leetcode之动态规划(DP)专题-188. 买卖股票的最佳时机 IV(Best Time to Buy and Sell Stock IV) 股票问题: 121. 买卖股票的最佳时机 122. ...
- Java实现 LeetCode 188 买卖股票的最佳时机 IV
188. 买卖股票的最佳时机 IV 给定一个数组,它的第 i 个元素是一支给定的股票在第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你最多可以完成 k 笔交易. 注意: 你不能同时参与多 ...
- 力扣 122 买卖股票的最佳时机II
力扣 122 买卖股票的最佳时机II 思路: 动态规划,表面上是\(O(2^n)\)的搜索空间,实际上该天的选择只与前一天的状态(是否持有股票)有关.从收益的角度来看,确实每一天的不同选择都会产生不同 ...
- Leetcode 188.买卖股票的最佳时机IV
买卖股票的最佳时机IV 给定一个数组,它的第 i 个元素是一支给定的股票在第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你最多可以完成 k 笔交易. 注意: 你不能同时参与多笔交易(你必 ...
- 刷题-力扣-122. 买卖股票的最佳时机 II
122. 买卖股票的最佳时机 II 题目链接 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/best-time-to-buy-and-sell ...
- leetcode 188. 买卖股票的最佳时机 IV
参见 本题采用了第一列初始化后,从左侧向右开始递推的方式,但从上往下递推应该也成立,以后尝试一下 想写一个普适性的适用于n天交易k次持有j股的状态方程但是有问题:对于交易次数过多的情况数组会超出界限: ...
- lintcode:买卖股票的最佳时机 IV
买卖股票的最佳时机 IV 假设你有一个数组,它的第i个元素是一支给定的股票在第i天的价格. 设计一个算法来找到最大的利润.你最多可以完成 k 笔交易. 注意事项 你不可以同时参与多笔交易(你必须在再次 ...
- 【LeetCode】188、买卖股票的最佳时机 IV
Best Time to Buy and Sell Stock IV 题目等级:Hard 题目描述: Say you have an array for which the ith element i ...
- 20201228 买卖股票的最佳时机 IV(困难)
给定一个整数数组 prices ,它的第 i 个元素 prices[i] 是一支给定的股票在第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你最多可以完成 k 笔交易. 注意:你不能同时参 ...
随机推荐
- 利用DNS缓存和TLS协议将受限SSRF变为通用SSRF
本文首发于先知社区 前言 这是今年BlackHat上的一个议题:When TLS Hacks You,作者是latacora的Joshua Maddux 议题提出了一个新的ssrf攻击思路,利用DNS ...
- 自动下载MarkDown格式会议论文的程序
近期师兄发给我一个压缩包让我整理文献,而我发现压缩包里的内容是这样: 这样: 和这样的: 我大概看了一下,可能有270多篇文章是这种格式,俗话说的好,没有困难的工作,只有勇敢的研究僧.所以决定用Pyt ...
- k8s endpoints controller分析
k8s endpoints controller分析 endpoints controller简介 endpoints controller是kube-controller-manager组件中众多控 ...
- C#与dotNET项目想要另存为一个新项目sln文件丢了怎么办
如下图所示,我想要另存一个工程,把 V4.4整个的项目另存为V4.5,我可以把解决方案文件(.sln)改名字,但是我没法把文件夹改名字,改了打开sln就说找不到. 很简单的一个思路是反正sln是多余的 ...
- vue中使用echarts,地图上的涟漪特效大小设置
在使用echarts进行开发大屏时,使用到了地图这个组件 我们会根据返回的值来决定涟漪的大小 这时则使用 其它的value为返回的数组,一般格式为[经度,维度,值] 这样就能动态设置效果的大小了
- [atARC126F]Affine Sort
记$g(k)$为$c$恰为$k$的合法三元组数,显然$f(k)=\sum_{i=1}^{k}g(i)$ 结论:若$\lim_{k\rightarrow \infty}\frac{g(k)}{k^{2} ...
- /dev/random 和 /dev/urandom 的原理
/dev/null 是一个特殊的设备文件,它丢弃一切写入其中的数据 可以将它 视为一个黑洞, 它等效于只写文件, 写入其中的所有内容都会消失, 尝试从中读取或输出不会有任何结果,同样,/dev/nul ...
- GPG 使用指南
加密与签名 在传输信息时,会面临两个典型的问题: 如何保证发出的消息,只能被预期的接收人获取? 如何保证收到的消息,确实由预期的发送人发出? 这两个问题不难理解.例如发送的邮件可能会被监听,诈骗分子可 ...
- HelloWorld与java运行机制
HelloWorld 新建文件夹存放代码 新建一个java文件 文件后缀为.java Hello.java 注意文件拓展名改为java文件 编写代码 public class Hello{ #类名 p ...
- 随笔:关于.net core单文件AOT编译
.Net Core单文件发布已经很流畅了(vs已支持图形化操作发布). 但类似Go或者Graalvm JDK的完全事前编译为本地机器码的红能功能,还未发布于.net 6特性中,还处于实验室中. 另外, ...