python买卖股票的最佳时机(基于贪心/蛮力算法)


Posted in Python onJuly 05, 2019

开始刷leetcode算法题 今天做的是“买卖股票的最佳时机”

题目要求

给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格。

设计一个算法来计算你所能获取的最大利润。你可以尽可能地完成更多的交易(多次买卖一支股票)。

注意:你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。

看到这个题目 最初的想法是蛮力法

通过两层循环 不断计算不同天之间的利润及利润和

下面上代码

class Solution(object):
  def maxProfit(self, prices):
    """
    :type prices: List[int]
    :rtype: int
    """

    self.allbuy1 = []  #单次买卖的差值数组 (可能为负)
    self.allbuy2 = []  #所有可能买卖的利润数组 (可能为负)
               # allbuy1和allbuy2的区别为一个是单次买卖 一个是多次买卖和
    self.curbuy(prices,0,0) #prices 为价格表 0:初始 0:
    #print(self.allbuy1)
    #print(self.allbuy2)
    return self.picBigest(self.allbuy2)
  def buyticket(self,prilist,a,b):    #list:放入的价格数组 a:上一次买入的价格 b:今天卖出的价格
    return prilist[b] -prilist[a]  #返回 赚取得价格

  def curbuy(self,plist,x,result): #plist:价格数组 x:当天的数组坐标 result: 利润
    obj=result           #固定上一次的价格 保存为上一个递归
    lens=len(plist)        #天数
    for i in range(x,lens-1):
      for j in range(i+1,lens):
        temp=self.buyticket(plist,i, j)
        self.allbuy1.append(temp)
        self.allbuy2.append(temp)   #单次利润放入数组
        result = obj + temp   #将之前的利润加上今天的利润
        if(x>=2):       #如果买入是第2+1天以后 则可以加上之前的利润
          self.allbuy2.append(result) #多次买卖利润放入数组
        self.curbuy(plist,j+1,result)  #递归 j+1:卖出的后一天 result:利润

  def picBigest(self,reslist): 
    big=0
    for i in reslist:
      if (i>big):
        big=i
    print(big)
    return big

if __name__ == '__main__':
    test=Solution()
    prices = [5,7,3,8] # 输入的每日股票数组
    test.maxProfit(prices)

分析:

这个代码理解起来简单 就是将所有可能都放入数组中 找出最大一个可能

将这个代码提交时 显示 超出时间限制 确实 如果输入的数组长度非常大时 计算量巨大 出现错误

——————————————————————————————————————————————————————————————————————————————

更换思路:利用贪心算法解决此事

首先介绍 一下贪心算法: 对问题只对当前情况进行最优解处理,之后发生什么对之前的决定都不改变。简单的说就是一个局部最优解的过程

介绍个例子就明白了: 找零钱问题

假设有面值为5元、2元、1元、5角、2角、1角的货币,需要找给顾客4元6角现金,为使付出的货币的数量最少

  • 首先找出小于4元6角的最大面值(2元)

  • 其次找出小于2元6角的最大面值(2元)

  • 接着找出小于6角的最大面值(5角)

  • 最后找出小于1角的最大面值(1角) ---付出4张纸币

介绍完了贪心算法简单思想 就利用该方法解决对应问题

在已知股票价格走势情况下 只需要对下一天进行判断 如果涨了 则买 如果跌了则卖 这样收益会保持固定增长

当然了 有人会提出 我可以选择不卖等几天再卖 或不买等几天再买 的方式 一样可以保持增长 但是如图

python买卖股票的最佳时机(基于贪心/蛮力算法)

如果在第2天买入 3天卖出 4天买入 5天卖出 收益为A+B

如果在第2天买入 5天卖出 收益为 C

明显得出A+B大于C 所以贪心法在这种情况非常适用并且肯定得到最优解

直接上代码

class Solution(object):
  def maxProfit(self, prices):
    profit = 0
    for day in range(len(prices)-1):
      differ = prices[day+1] - prices[day]
      if differ > 0:
        profit += differ
    return profit
if __name__ == '__main__':
    test=Solution()
    prices = [5,7,3,9] # 输入的每日股票数组
    print(test.maxProfit(prices))

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
修改Python的pyxmpp2中的主循环使其提高性能
Apr 24 Python
python正则分析nginx的访问日志
Jan 17 Python
python+selenium实现登录账户后自动点击的示例
Dec 22 Python
简单实现Python爬取网络图片
Apr 01 Python
使用实现XlsxWriter创建Excel文件并编辑
May 04 Python
pygame实现雷电游戏雏形开发
Nov 20 Python
Python基于滑动平均思想实现缺失数据填充的方法
Feb 21 Python
详解Python下载图片并保存本地的两种方式
May 15 Python
Django Docker容器化部署之Django-Docker本地部署
Oct 09 Python
如何给Python代码进行加密
Jan 10 Python
Python+Opencv身份证号码区域提取及识别实现
Aug 25 Python
pytorch MSELoss计算平均的实现方法
May 12 Python
Python 计算任意两向量之间的夹角方法
Jul 05 #Python
python实现两个经纬度点之间的距离和方位角的方法
Jul 05 #Python
Python3+Appium实现多台移动设备操作的方法
Jul 05 #Python
Python PIL读取的图像发生自动旋转的实现方法
Jul 05 #Python
python读出当前时间精度到秒的代码
Jul 05 #Python
python读写csv文件方法详细总结
Jul 05 #Python
Python考拉兹猜想输出序列代码实践
Jul 05 #Python
You might like
模拟SQLSERVER的两个函数:dateadd(),datediff()
2006/10/09 PHP
解析php中如何直接执行SHELL
2013/06/28 PHP
php实现mysql数据库连接操作及用户管理
2015/11/08 PHP
24条货真价实的PHP代码优化技巧
2016/07/28 PHP
ThinkPHP3.2.3框架实现执行原生SQL语句的方法示例
2019/04/03 PHP
javascript 设为首页与加入收藏兼容多浏览器代码
2011/01/11 Javascript
TimergliderJS 一个基于jQuery的时间轴插件
2011/12/07 Javascript
使用js操作cookie的一点小收获分享
2013/09/03 Javascript
javascript简单事件处理和with用法介绍
2013/09/16 Javascript
Javascript简单实现可拖动的div
2013/10/22 Javascript
举例讲解Node.js中的Writable对象
2015/07/29 Javascript
jQuery mobile类库使用时加载导航历史的方法简介
2015/12/04 Javascript
实例讲解jQuery EasyUI tree中state属性慎用
2016/04/01 Javascript
jQuery Mobile中的button按钮组件基础使用教程
2016/05/23 Javascript
AngularJS中的表单简单入门
2016/07/28 Javascript
Angular2中Bootstrap界面库ng-bootstrap详解
2016/10/18 Javascript
JavaScript自动点击链接 防止绕过浏览器访问的方法
2017/01/19 Javascript
微信小程序提交form操作示例
2018/12/30 Javascript
JavaScript 处理树数据结构的方法示例
2019/06/16 Javascript
jQuery实现高度灵活的表单验证功能示例【无UI】
2020/04/30 jQuery
python模拟登陆Tom邮箱示例分享
2014/01/13 Python
Python 使用os.remove删除文件夹时报错的解决方法
2017/01/13 Python
Python实现邮件的批量发送的示例代码
2018/01/23 Python
Python高级用法总结
2018/05/26 Python
python 对key为时间的dict排序方法
2018/10/17 Python
Pandas 重塑(stack)和轴向旋转(pivot)的实现
2019/07/22 Python
python使用gdal对shp读取,新建和更新的实例
2020/03/10 Python
Iconfont(矢量图标)+iconmoon(图标svg互转)配合javascript实现社交分享系统
2020/04/21 Python
PHP中如何使用Cookie
2015/10/28 面试题
房地产开发计划书
2014/01/10 职场文书
中学家长会邀请函
2014/02/03 职场文书
模具毕业生推荐信
2014/02/15 职场文书
道路建设实施方案
2014/03/18 职场文书
后天观后感
2015/06/08 职场文书
公务员处分决定书
2015/06/25 职场文书
Python还能这么玩之用Python做个小游戏的外挂
2021/06/04 Python