Leetcode--188. 买卖股票的最佳时机Ⅳ

给定一个数组,它的第 i 个元素是一支给定的股票在第 i 天的价格。

设计一个算法来计算你所能获取的最大利润。你最多可以完成 k 笔交易。

注意: 你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。

示例 1:

输入: [2,4,1], k = 2
输出: 2
解释: 在第 1 天 (股票价格 = 2) 的时候买入,在第 2 天 (股票价格 = 4) 的时候卖出,这笔交易所能获得利润 = 4-2 = 2 。
示例 2:

输入: [3,2,6,5,0,3], k = 2
输出: 7
解释: 在第 2 天 (股票价格 = 2) 的时候买入,在第 3 天 (股票价格 = 6) 的时候卖出, 这笔交易所能获得利润 = 6-2 = 4 。
     随后,在第 5 天 (股票价格 = 0) 的时候买入,在第 6 天 (股票价格 = 3) 的时候卖出, 这笔交易所能获得利润 = 3-0 = 3 。

思路:同之前的允许交易两次的题类似,只不过把交易次数k变大

但需要注意,这道题定义dp[length][k][2],会超出内存限制,所有应该是k过大,k最大不过是数组的一半,他的交易数量不可能超过这个值,所以当交易次数超过数组长度一半时,调用之前的方法maxProfit1,k视为无限大,可以忽略,定义dp[length][2]

之前交易两次的链接:https://mp.csdn.net/postedit/102924843

提交的代码:

class Solution {
    public static int maxProfit1(int[] prices) {
    int sum=0;
        for(int i=1;i<prices.length;i++)
        {
            if(prices[i]-prices[i-1]>0)
            {
                sum+=prices[i]-prices[i-1];
            }
        }
        return sum;
    }
    public int maxProfit(int k, int[] prices) {
        if(k>prices.length/2)
        {
            return maxProfit1(prices);
        }
        if(prices.length==0||k==0)
    {
        return 0;
    }
    int dp[][][] = new int[prices.length][k+1][2];
    dp[0][0][0] = 0;
    dp[0][0][1] = Integer.MIN_VALUE >> 1;
    for(int i=1;i<=k;i++)
    {
        dp[0][i][0]=0;
        dp[0][i][1]=-prices[0];
    }
    dp[0][1][1] = -prices[0];
    for(int i=1;i<prices.length;i++)
    {
        for(int j = 1;j<=k;j++)
        {
            dp[i][j][0]=Math.max(dp[i-1][j][0],dp[i-1][j][1]+prices[i]);
            dp[i][j][1]=Math.max(dp[i-1][j][1],dp[i-1][j-1][0]-prices[i]);    
        }
    }
    int max = dp[prices.length-1][0][0];
    for(int i=1;i<=k;i++)
    {
        if(dp[prices.length-1][k][0]>max)
        {
            max = dp[prices.length-1][k][0];
        }
    }
    return max;

    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/485728.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java comparator内部类_java - Java Comparator使用.reverseOrder()但内部类 - 堆栈内存溢出...

我正在创建一个简单的程序来了解Java Comparator类。 我已经按顺序对一个Arraylist了排序&#xff0c;但现在我想按降序对列表进行排序&#xff0c;但是我在调​​用.reverseOrder()方法时遇到问题&#xff0c;因为我使用了一个实现Comparator的内部类(歌曲是一首歌)容纳吸气剂…

继续深入更新shell脚本容易出错的地方

一、在shell中用到如果需要输入某些值&#xff0c;需要用到read -p命令 这是我写的猜数字游戏&#xff0c;一开始在输出的时候&#xff0c;屏幕上总会打印输出 "INT" 经过反复的练习才发现 双引号后面应该跟着一个空格&#xff0c;然后在写变量&#xff0c;就不会把…

中国工程院发布2021中国电子信息工程科技发展十四大趋势

来源&#xff1a;人民邮电报1月5日&#xff0c;中国工程院信息与电子工程科技发展战略研究中心发布“中国电子信息工程科技发展十四大趋势&#xff08;2021&#xff09;”。这十四大趋势涵盖信息化、计算机系统与软件、网络与通信、计算机应用、网络安全、集成电路、数据、感知…

AcWing--2.01背包问题

有 NN 件物品和一个容量是 VV 的背包。每件物品只能使用一次。 第 ii 件物品的体积是 vivi&#xff0c;价值是 wiwi。 求解将哪些物品装入背包&#xff0c;可使这些物品的总体积不超过背包容量&#xff0c;且总价值最大。 输出最大价值。 输入格式 第一行两个整数&#xff…

java实现数组排序代码_Java使用选择排序法对数组排序实现代码

编写程序&#xff0c;实现将输入的字符串转换为一维数组&#xff0c;并使用选择排序法对数组进行排序。思路如下&#xff1a;点击"生成随机数"按钮&#xff0c;创建Random随机数对象&#xff1b;使用JTextArea的setText()方法清空文本域&#xff1b;创建一个整型一维…

Python题整理

1、Python的多态、鸭子类型&#xff1f; 2、Python的序列化工具有哪些&#xff1f; 3、Python处理Excel的工具有哪些&#xff1f; 4、Python处理Graph的算法库有哪些&#xff1f; 5、Python的dict是基于什么数据结构实现的&#xff1f;优点和缺点是什么&#xff1f; 6、 对于di…

ICinsights:中国芯片难达成既定的2025目标

来源&#xff1a;内容由半导体行业观察&#xff08;ID&#xff1a;icbank&#xff09;综合自「ICinsights」&#xff0c;谢谢。据知名分析机构ICinsights报道&#xff0c;在中国的集成电路市场和中国的本土集成电路生产之间应该有一个非常明显的区别。正如IC Insights经常指出的…

AcWing:3.完全背包问题

有 NN 种物品和一个容量是 VV 的背包&#xff0c;每种物品都有无限件可用。 第 ii 种物品的体积是 vivi&#xff0c;价值是 wiwi。 求解将哪些物品装入背包&#xff0c;可使这些物品的总体积不超过背包容量&#xff0c;且总价值最大。 输出最大价值。 输入格式 第一行两个整…

html与js与mysql_WebView加载html与JS交互

一、加载Html的几种方法直接在Activity中实例化WebViewWebView webview new WebView(this);webview.loadUrl(......);在XML中生命webviewWebView webView (WebView) findViewById(R.id.webview);载入工程内部页面 page.html存储在工程文件的assets根目录下webView (WebView) …

2021年5G发展展望

来源&#xff1a;中国电子信息产业发展研究院&#xff08;转载请注明来源&#xff09;编辑&#xff1a; 蒲蒲日前&#xff0c;在2020通信产业大会暨第十五届通信技术年会上&#xff0c;工信部赛迪智库发布了《5G发展2021展望白皮书》。白皮书内容包括对2021年5G形势的基本判断、…

博弈论笔记--03--迭代剔除和中位选民定理

迭代剔除策略:先站在所有人的角度&#xff0c;删除所有的劣势策略&#xff0c;然后重复这个过程。Game One--中间选民定理的例子博弈者&#xff1a;2个Players需要选择自己的政治立场。策略选项&#xff1a;一共有1-10种政治立场&#xff0c;每种都有10%的选民支持。收益:候选者…

Leetcode--136. 只出现一次的数字

给定一个按照升序排列的整数数组 nums&#xff0c;和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。 你的算法时间复杂度必须是 O(log n) 级别。 如果数组中不存在目标值&#xff0c;返回 [-1, -1]。 示例 1: 输入: nums [5,7,7,8,8,10], target 8 输…

喜忧参半:我国蜂窝物联网全球占比超过75%

来源: C114通信网随着连接技术的不断创新&#xff0c;我们将迎来真正万物互联的智能世界。而在物联网产业链条中&#xff0c;通信运营商一直扮演着至关重要的角色。知名物联网市场研究机构IoT Analytics的数据显示&#xff1a;蜂窝物联网连接数方面&#xff0c;中国电信、中国联…

java ant war包_java利用Ant脚本生成war包全过程

使用ant脚本前的准备1、下载一个ant安装包。如&#xff1a;apache-ant-1.8.4-bin.zip。解压到E盘。2、配置环境变量。新增ANT_HOME&#xff1a;E:\apache-ant-1.8.4&#xff1b;PATH增加&#xff1a;E:\apache-ant-1.8.4\bin。3、检查ant是否配置完成。运行->cmd输入&#x…

class(一)--类的创建

class是ES6引入的&#xff0c;它并不是一种全新的继承模式&#xff0c;而只是基于原型对象继承封装的语法糖&#xff0c;因此只要充分理解原型对象&#xff0c;原型链&#xff0c;继承等知识&#xff0c;class也就很好容易理解了 类的声明 ES5及之前是通过创建一个构造函数(Fn)…

Leetcode--84. 柱状图中最大的矩形

给定 n 个非负整数&#xff0c;用来表示柱状图中各个柱子的高度。每个柱子彼此相邻&#xff0c;且宽度为 1 。 求在该柱状图中&#xff0c;能够勾勒出来的矩形的最大面积。 以上是柱状图的示例&#xff0c;其中每个柱子的宽度为 1&#xff0c;给定的高度为 [2,1,5,6,2,3]。 图…

2021机器智能研究方向

来源&#xff1a;人工智能和大数据 在机器智能向更大的深度神经网络发展的过程中&#xff0c;训练效率将成为Graphcore Research在2021年的重点工作。大型、过参数化模型的训练不断展现出改进的训练和泛化性能。事实上&#xff0c;在许多领域&#xff0c;较大的模型样本效率更高…

php操作redis_PHP操作Redis的基本方法

redis 的基本操作方法1 redis 的连接 &#xff1a;//实例化redis $redis new Redis(); //连接 $redis->connect(127.0.0.1, 6379); //检测是否连接成功 echo "Server is running: " . $redis->ping(); // 输出结果 Server is running: PONG2 redis 操作 Strng…

sqlalchemy外键和relationship查询

前面的文章中讲解了外键的基础知识和操作&#xff0c;上一篇文章讲解了sqlalchemy的基本操作。前面两篇文章都是作为铺垫&#xff0c;为下面的文章打好基础。记得初一时第一次期中考试时考的不好&#xff0c;老爸安慰我说&#xff1a;“学习是一个循序渐进的过程”&#xff0c;…

Leetcode--152. 乘积最大子序列

给定一个整数数组 nums &#xff0c;找出一个序列中乘积最大的连续子序列&#xff08;该序列至少包含一个数&#xff09;。 示例 1: 输入: [2,3,-2,4] 输出: 6 解释: 子数组 [2,3] 有最大乘积 6。 示例 2: 输入: [-2,0,-1] 输出: 0 解释: 结果不能为 2, 因为 [-2,-1] 不是子…