LeetCode 123买卖股票的最佳时机-iii 188买卖股票的最佳时机-iv | 代码随想录25期训练营day50

本文主要是介绍LeetCode 123买卖股票的最佳时机-iii 188买卖股票的最佳时机-iv | 代码随想录25期训练营day50,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

动态规划算法8

LeetCode 123 买卖股票的最佳时机-iii 2023.12.13

  • 题目链接
  • 代码随想录讲解[链接]
    在这里插入图片描述
int maxProfit(vector<int>& prices) {//1确定dp二维数组//dp[i][0]表示遍历到第i天时第一次持有股票的当前收入;dp[i][1]表示遍历到第i天时第一次未持有股票的当前收入//dp[i][2]表示遍历到第i天时第二次持有股票的当前收入;dp[i][3]表示遍历到第i天时第二次未持有股票的当前收入vector<vector<int>> dp(prices.size(), vector<int>(4, 0));//3初始化,第一天第一次与第二次持有股票的收入为-prices[0],其他值为0dp[0][0] = -prices[0];dp[0][2] = -prices[0];//2确定递推公式,4确定遍历顺序for (int i = 1; i < prices.size(); i++){//第i天第一次持有股票的收入=max(股票不卖(上一天第一次持有股票的收入),第一次买完今天的股票的收入)dp[i][0] = max(dp[i-1][0], -prices[i]);//第i天第一次未持有股票的收入=max(上一天第一次未持有股票的收入,今天第一次卖股票的收入)dp[i][1] = max(dp[i-1][1], dp[i-1][0]+prices[i]);//第i天第二次持有股票的收入=max(股票不卖(上一天第二次持有股票的收入),第二次买完今天的股票的收入)dp[i][2] = max(dp[i-1][2], dp[i-1][1]-prices[i]);//第i天第二次未持有股票的收入=max(上一天第二次未持有股票的收入,今天第二次卖股票的收入)dp[i][3] = max(dp[i-1][3], dp[i-1][2]+prices[i]);}//输出答案为最后一天第二次未持有股票的结果return dp[prices.size()-1][3];
}

LeetCode 188 买卖股票的最佳时机-iv 2023.12.13

  • 题目链接
  • 代码随想录讲解[链接]
    在这里插入图片描述
int maxProfit(int k, vector<int>& prices) {//1确定dp二维数组//dp[i][0]表示遍历到第i天时第一次持有股票的当前收入;dp[i][1]表示遍历到第i天时第一次未持有股票的当前收入//dp[i][2*j]表示遍历到第i天时第j+1次持有股票的当前收入;dp[i][2*j+1]表示遍历到第i天时第j+1次未持有股票的当前收入vector<vector<int>> dp(prices.size(), vector<int>(2*k, 0));//3初始化,第一天第一次到第k次持有股票的收入为-prices[0],其他值为0for (int i = 0; i < 2*k; i += 2)dp[0][i] = -prices[0];//2确定递推公式,4确定遍历顺序for (int i = 1; i < prices.size(); i++){for (int j = 0; j < 2*k; j += 2){//第i天第一次持有股票的收入=max(股票不卖(上一天第一次持有股票的收入),第一次买完今天的股票的收入)if(j == 0)dp[i][j] = max(dp[i-1][j], -prices[i]);//第i天第j次持有股票的收入=max(股票不卖(上一天第j次持有股票的收入),第j次买完今天的股票的收入)elsedp[i][j] = max(dp[i-1][j], dp[i-1][j-1]-prices[i]);//第i天第j次未持有股票的收入=max(上一天第j次未持有股票的收入,今天第j次卖股票的收入)dp[i][j+1] = max(dp[i-1][j+1], dp[i-1][j]+prices[i]);}}//输出答案为最后一天第k次未持有股票的结果return dp[prices.size()-1][2*k-1];
}

这篇关于LeetCode 123买卖股票的最佳时机-iii 188买卖股票的最佳时机-iv | 代码随想录25期训练营day50的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/492160

相关文章

哈希leetcode-1

目录 1前言 2.例题  2.1两数之和 2.2判断是否互为字符重排 2.3存在重复元素1 2.4存在重复元素2 2.5字母异位词分组 1前言 哈希表主要是适合于快速查找某个元素(O(1)) 当我们要频繁的查找某个元素,第一哈希表O(1),第二,二分O(log n) 一般可以分为语言自带的容器哈希和用数组模拟的简易哈希。 最简单的比如数组模拟字符存储,只要开26个c

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

代码随想录冲冲冲 Day39 动态规划Part7

198. 打家劫舍 dp数组的意义是在第i位的时候偷的最大钱数是多少 如果nums的size为0 总价值当然就是0 如果nums的size为1 总价值是nums[0] 遍历顺序就是从小到大遍历 之后是递推公式 对于dp[i]的最大价值来说有两种可能 1.偷第i个 那么最大价值就是dp[i-2]+nums[i] 2.不偷第i个 那么价值就是dp[i-1] 之后取这两个的最大值就是d

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

leetcode-24Swap Nodes in Pairs

带头结点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val = x; }* }*/public class Solution {public ListNode swapPairs(L

leetcode-23Merge k Sorted Lists

带头结点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val = x; }* }*/public class Solution {public ListNode mergeKLists

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

D4代码AC集

贪心问题解决的步骤: (局部贪心能导致全局贪心)    1.确定贪心策略    2.验证贪心策略是否正确 排队接水 #include<bits/stdc++.h>using namespace std;int main(){int w,n,a[32000];cin>>w>>n;for(int i=1;i<=n;i++){cin>>a[i];}sort(a+1,a+n+1);int i=1