leetcode_c++:Best Time to Buy and Sell Stock III(123)
2016-06-10 23:57
549 查看
题目
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 at most two transactions.
算法
题意:用一个数组表示股票每天的价格,数组的第i个数表示股票在第i天的价格。最多交易两次,手上最多只能持有一支股票,求最大收益。分析:动态规划法。以第i天为分界线,计算第i天之前进行一次交易的最大收益preProfit[i],和第i天之后进行一次交易的最大收益postProfit[i],最后遍历一遍,max{preProfit[i] + postProfit[i]} (0≤i≤n-1)就是最大收益。第i天之前和第i天之后进行一次的最大收益求法同Best Time to Buy and Sell Stock I。
代码:时间O(n),空间O(n)。
class Solution { public: int maxProfit(vector<int>& prices) { if(prices.size()<2) return 0; int n=prices.size(); vector<int> preprofile(n); vector<int> postprofile(n); int curmin=prices[0]; for(int i=1;i<n;i++){ curmin=min(curmin,prices[i]); preprofile[i]=max(preprofile[i-1],prices[i]-curmin); } int curmax=prices[n-1]; for(int i=n-2;i>=0;i--){ curmax=max(curmax,prices[i]); postprofile[i]=max(postprofile[i+1],curmax-prices[i]); } int maxprofile=0; for(int i=0;i<n;i++){ maxprofile=max(maxprofile,preprofile[i]+postprofile[i]); } return maxprofile; } };
相关文章推荐
- 递归和迭代的区别
- Binary Tree Level Order Traversal
- Maximum Depth of Binary Tree
- leetcode_c++:Best Time to Buy and Sell Stock II(122)
- Leetcode_c++: Best Time to Buy and Sell Stock (121)
- Binary Tree Level Order Traversal II
- c++:角色类
- C++入门之一【类:析构函数)】
- Leetcode_c++: Triangle (120)
- c语言:递归求最大公约数
- VC++6.0玩OpenGL(一)
- Leetcode_c++: Pascal's TriangleII (119)
- C++操作符函数
- 找出字符串中的所有数字字符串(C/C++实现)
- Leetcode_c++: Pascal's Triangle(118)
- C++中的const用法
- Leetcode_c++:Construct Binary Tree from Inorder and Postorder Traversal (106)
- SCPPO(三):禅道的使用—项目管理员、开发等人员
- 指针和引用
- win7旗舰版安装VC++6.0番茄插件和行号显示