LintCode--best-time-to-buy-and-sell-stock-ii(买卖股票的最佳时机 II)
2015-09-19 20:12
686 查看
原题链接:http://www.lintcode.com/zh-cn/problem/best-time-to-buy-and-sell-stock-ii/
假设有一个数组,它的第i个元素是一个给定的股票在第i天的价格。设计一个算法来找到最大的利润。你可以完成尽可能多的交易(多次买卖股票)。然而,你不能同时参与多个交易(你必须在再次购买前出售股票)。
样例
给出一个数组样例[2,1,2,0,1], 返回 2
分析:
只要收益为正的,就加上。
时间复杂度 O(n)
代码(C++、Python、Java)
class Solution {
public:
/**
* @param prices: Given an integer array
* @return: Maximum profit
*/
int maxProfit(vector<int> &prices) {
// write your code here
int n = prices.size();
int res = 0;
for (int i = 0; i < n-1; i ++)
if (prices[i+1] - prices[i] > 0)
res += prices[i+1] - prices[i];
return res;
}
};
假设有一个数组,它的第i个元素是一个给定的股票在第i天的价格。设计一个算法来找到最大的利润。你可以完成尽可能多的交易(多次买卖股票)。然而,你不能同时参与多个交易(你必须在再次购买前出售股票)。
样例
给出一个数组样例[2,1,2,0,1], 返回 2
分析:
只要收益为正的,就加上。
时间复杂度 O(n)
代码(C++、Python、Java)
class Solution {
public:
/**
* @param prices: Given an integer array
* @return: Maximum profit
*/
int maxProfit(vector<int> &prices) {
// write your code here
int n = prices.size();
int res = 0;
for (int i = 0; i < n-1; i ++)
if (prices[i+1] - prices[i] > 0)
res += prices[i+1] - prices[i];
return res;
}
};
class Solution { /** * @param prices: Given an integer array * @return: Maximum profit */ public int maxProfit(int[] prices) { // write your code here int n = prices.length; int res = 0; for (int i = 0; i < n-1; i++) if (prices[i+1] - prices[i] > 0) res += prices[i+1] - prices[i]; return res; } };
class Solution: """ @param prices: Given an integer array @return: Maximum profit """ def maxProfit(self, prices): # write your code here n = len(prices) res = 0 for i in range(n-1): if prices[i+1] - prices[i] >= 0: res += prices[i+1] - prices[i] return res
相关文章推荐
- 动易2006序列号破解算法公布
- Ruby实现的矩阵连乘算法
- C#插入法排序算法实例分析
- 超大数据量存储常用数据库分表分库算法总结
- C#数据结构与算法揭秘二
- C#冒泡法排序算法实例分析
- 算法练习之从String.indexOf的模拟实现开始
- C#算法之关于大牛生小牛的问题
- C#实现的算24点游戏算法实例分析
- c语言实现的带通配符匹配算法
- 浅析STL中的常用算法
- 算法之排列算法与组合算法详解
- C++实现一维向量旋转算法
- Ruby实现的合并排序算法
- C#折半插入排序算法实现方法
- 基于C++实现的各种内部排序算法汇总
- C++线性时间的排序算法分析
- C++实现汉诺塔算法经典实例
- PHP实现克鲁斯卡尔算法实例解析
- C#获取关键字附近文字算法实例