122. 买卖股票的最佳时机 II

题目

给你一个整数数组 prices ,其中 prices[i] 表示某支股票第 i 天的价格。

在每一天,你可以决定是否购买和/或出售股票。你在任何时候 最多 只能持有 一股 股票。然而,你可以在 同一天 多次买卖该股票,但要确保你持有的股票不超过一股。

返回 你能获得的 最大 利润 。

例子

输入:prices = [7,1,5,3,6,4]

输出:7

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

随后,在第 4 天(股票价格 = 3)的时候买入,在第 5 天(股票价格 = 6)的时候卖出, 这笔交易所能获得利润 = 6 - 3 = 3。

最大总利润为 4 + 3 = 7

解法一

  1. 若价格一直往下跌,不买入
  2. 假设第一天买入,若买入后价格往下跌,应该下一天买入
  3. 若下一天价格往下跌,应该当天卖出
  4. 若到最后一天,应该清盘,若之前买入卖出,否则维持现状
public int maxProfit(int[] prices) {
if (prices == null || prices.length <= 1)
return 0; int maxProfit = 0, minPrice = prices[0];
for (int i = 1; i < prices.length; i++) {
if (prices[i] < minPrice) { // 若价格比之前低,应该买入
minPrice = prices[i];
} else if (i == prices.length - 1) { // 最后一天,强制清盘
if (prices[i] - minPrice > 0) {
maxProfit += (prices[i] - minPrice);
}
} else if (prices[i + 1] < prices[i]) { // 若后一天价格比当前低&&之前已经买入,就应该当天卖出
maxProfit += (prices[i] - minPrice);
minPrice = prices[i + 1];
} System.out.println(
String.join(",", String.valueOf(prices[i]), String.valueOf(minPrice), String.valueOf(maxProfit)));
}
return maxProfit;
}

解法二

贪心算法,若当天价格比前一天高,即可卖出,获取利润,统计结果利润

public int maxProfit(int[] prices) {
if (prices == null || prices.length <= 1)
return 0; int maxProfit = 0;
for (int i = 1; i < prices.length; i++) {
maxProfit += Math.max(0, prices[i] - prices[i - 1]);
}
return maxProfit;
}

【LeetCode】122. 买卖股票的最佳时机 II的更多相关文章

  1. Java实现 LeetCode 122 买卖股票的最佳时机 II

    122. 买卖股票的最佳时机 II 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你可以尽可能地完成更多的交易(多次买卖一支股票). 注意: ...

  2. LeetCode(122. 买卖股票的最佳时机 II)

    问题描述 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你可以尽可能地完成更多的交易(多次买卖一支股票). 注意:你不能同时参与多笔交易(你 ...

  3. Leetcode 122.买卖股票的最佳时机II

    给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你可以尽可能地完成更多的交易(多次买卖一支股票). 注意:你不能同时参与多笔交易(你必须在再次 ...

  4. LeetCode 122. 买卖股票的最佳时机 II(Best Time to Buy and Sell Stock II)

    题目描述 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你可以尽可能地完成更多的交易(多次买卖一支股票). 注意:你不能同时参与多笔交易(你 ...

  5. leetcode 122. 买卖股票的最佳时机 II (python)

    给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你可以尽可能地完成更多的交易(多次买卖一支股票). 注意:你不能同时参与多笔交易(你必须在再次 ...

  6. [LeetCode] 122. 买卖股票的最佳时机ii best-time-to-buy-and-sell-stock-ii(贪心算法)

    思路: 只要第二天的价格高于第一天,就进行交易.(这样的话就默认可以同一天内先卖出再买进) class Solution(object): def maxProfit(self, prices): & ...

  7. 【Leetcode】【简单】【122. 买卖股票的最佳时机 II】【JavaScript】

    题目描述 122. 买卖股票的最佳时机 II 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你可以尽可能地完成更多的交易(多次买卖一支股票) ...

  8. Leetcode之动态规划(DP)专题-122. 买卖股票的最佳时机 II(Best Time to Buy and Sell Stock II)

    Leetcode之动态规划(DP)专题-122. 买卖股票的最佳时机 II(Best Time to Buy and Sell Stock II) 股票问题: 121. 买卖股票的最佳时机 122. ...

  9. 刷题-力扣-122. 买卖股票的最佳时机 II

    122. 买卖股票的最佳时机 II 题目链接 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/best-time-to-buy-and-sell ...

  10. 【力扣】122. 买卖股票的最佳时机 II

    给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你可以尽可能地完成更多的交易(多次买卖一支股票). 注意:你不能同时参与多笔交易(你必须在再次 ...

随机推荐

  1. DXF 最简单的一个文件生成两个直线一条直线放入BLOCKS中通过INSERT插入 (2)

    把#注解删除 0 SECTION 2 HEADER 9 $ACADVER 1 AC1009 9 $INSBASE 10 0.000000 20 0.000000 30 0.000000 9 $EXTM ...

  2. C++11 result_of 学习

    简介 std::result_of<Function(Args...)>::type 简而言之就是推断 Function(Args...) 这个函数的返回值类型,用在模板函数中 参考链接 ...

  3. java 打印日历

    简介 示例代码 Result Mon Tue Wed Thu Fri Sat Sun 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 ...

  4. Django--数据管理系统

    目录 Django--数据管理系统 数据库操作: python内对数据库的操作: 运行更新数据库.运行项目: 网页代码继承: 框架内代码: html网页代码: Django--数据管理系统 数据库操作 ...

  5. C-Kermit Scripting Tutorial and Library

    C-Kermit Scripting Tutorial and Library: https://kermitproject.org/ckscripts.html Useful Options: -- ...

  6. SciTech-EECS-Sensor:TI的 4-20mA 环路供电系统实现高达 100m 的液位测量,具有高测距精度和低功耗

    https://www.ti.com.cn/zh-cn/featured-applications-content/sensors/mmwave-radar/industrial-mmwave-lev ...

  7. MySQL报'Access denied for user 'root'@'localhost' (using password: NO)'错误的解决--九五小庞

    当在命令提示符下执行该命令时,报下列错误 [root@clvn]# mysqladmin -u root password "sorry"mysqladmin: connect t ...

  8. SoapUI使用教程-九五小庞

    一.简介SoapUI:常用的接口测试工具,掌握了能更好进行接口的开发. 二.Http接口调用1.创建项目 2.输入http请求地址 3.选择对应项目的request,输入信息发送请求 三.Webser ...

  9. Windows10系统电脑麦克风没声音的问题

    有电脑基地的用户在使用win10系统的时候,出现使用耳机连接的麦克风不能用,和别人聊天的时候没有声音.小伙伴很着急,不知道该怎么办?下面技术员小编就来分享详细的解决方法. Windows 10 下麦克 ...

  10. vue项目发布到docker nginx的方法总结

    我总结了以下两种方法可用 一.通过制作镜像,使用镜像生成docker   这个是比较常用的方法,制作镜像(images)后,如果还要生成docker可以直接使用镜像比较方便以下是操作步骤 1.创建目录 ...