博客
关于我
【leetcode】741买卖股票的最佳时机含手续费 | 动态规划 | 贪心
阅读量:264 次
发布时间:2019-03-01

本文共 1019 字,大约阅读时间需要 3 分钟。

为了解决这个问题,我们需要找到一种方法来最大化通过多次买卖股票获得的利润,同时考虑交易手续费的影响。我们可以使用贪心算法来优化交易策略,确保每次交易都能带来最大的利润。

方法思路

贪心算法的核心思想是每次尽可能地卖出股票,以获得当前最高的利润。具体步骤如下:

  • 初始化:记录当前手上的股票的最低买入价格。初始时,买入第一个股票并支付手续费。
  • 遍历价格数组:对于每一个股票价格:
    • 如果当前价格加上手续费低于当前的最低买入价格,更新最低买入价格。
    • 如果当前价格高于当前的最低买入价格,卖出股票,获得利润,并更新最低买入价格为当前价格。
  • 计算总利润:每次卖出股票时累加利润,最后返回总利润。
  • 这种方法确保了我们总是在最佳时机卖出股票,从而最大化利润。

    解决代码

    public class Solution {    public int maxProfit(vector
    prices, int fee) { int n = prices.size(); if (n <= 1) { return 0; } int buy = prices[0] + fee; int profit = 0; for (int i = 1; i < n; ++i) { if (prices[i] + fee < buy) { buy = prices[i] + fee; } else if (prices[i] > buy) { profit += prices[i] - buy; buy = prices[i]; } } return profit; }}

    代码解释

  • 初始化buy 初始化为第一个股票价格加上手续费,表示当前手上的股票的最低买入价格。
  • 遍历数组:从第二个股票价格开始,检查当前价格是否可以更新buy,或者是否可以卖出股票获得利润。
  • 更新利润:每次卖出股票时,计算利润并累加到profit中。
  • 返回结果:遍历结束后,返回累计的最大利润。
  • 这种方法的时间复杂度为O(n),空间复杂度为O(1),非常高效,适用于大规模数据。

    转载地址:http://poox.baihongyu.com/

    你可能感兴趣的文章
    PHP扩展数据库连接参数说明详解
    查看>>
    php把get参数放入数组_php怎么将数组转为url参数?
    查看>>
    php接口返回数据 用echo 还是return?
    查看>>
    php接口返回状态,大家一般怎么规范接口返回内容
    查看>>
    php接收formdata上传的多个文件,使用formData()上传多个文件
    查看>>
    PHP操作csv文件导入+导出
    查看>>
    php操作mysql用select_php如何操作mysql获取select 结果
    查看>>
    PHP操作符与控制结构
    查看>>
    PHP支付宝SDK使用,电脑网页支付
    查看>>
    php支付宝手机网页支付类实例
    查看>>
    PHP改变数组key值的方法
    查看>>
    php教程之php空白页的原因及解决方法
    查看>>
    PHP数据库操作
    查看>>
    PHP数据文件过大,导致PHP加速器eaccelerator在PHP5.2版本下崩溃
    查看>>
    RabbitMQ - 死信、TTL原理、延迟队列安装和配置
    查看>>
    PHP数据访问的多重查询(租房子查询)
    查看>>
    RabbitMQ - 如保证消息的可靠性?(消息确认、消息持久化、失败重试机制)
    查看>>
    RabbitMQ - 基于 SpringAMQP 带你实现五种消息队列模型
    查看>>
    php数组函数分析--array_column
    查看>>
    php数组去重复数据的小例子
    查看>>