当前位置: 首页 > news >正文

Python每日一练---第一天:买卖股票的最佳时机

前言📢📢

Python每日一练来啦,本文已收录于:《Python每日一练》专栏

此专栏目的在于,帮忙学习Python的小白提高编程能力,训练逻辑思维,持续更新中,欢迎免费订阅!!!

  • 1. 问题描述

给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。
你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。
返回你可以从这笔交易中获取的最大利润。如果你不能获取任何利润,返回 0 。
示例 1:
输入:[7,1,5,3,6,4]输出:5解释:在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5 。 注意利润不能是 7-1 = 6, 因为卖出价格需要大于买入价格;同时,你不能在买入前卖出股票。
示例 2:
输入:prices = [7,6,4,3,1]输出:0解释:在这种情况下, 没有交易完成, 所以最大利润为 0。
提示:
  • 1 <= prices.length <= 105
  • 0 <= prices[i] <= 104
  • 2. 问题分析

这个问题本质上是在一个数组(每日股价)中,寻找一对(i,j)(其中i<j),使得prices[j]-prices[i]的值最大。必须是先买入,再卖出,而且只能进行一次交易。

  • 3. 算法思路

思路一:暴力枚举(效率低,对于测试数据量大的会超时)

第一步:找出前i天的最低价

第二步:找出i天后的最高价

第三步:计算利润prices[j] - prices[i], 并记录最大值

思路二:动态规划思路,一次遍历

第一步:使用一个变量min_price记录到i天为止所遇到的最低价

第二步:再使用一个变量max_profit来记录到今天为止能获得的最大利润

第三步:变量整个价格数组

        更新min_price: min_price = min(min_price, prices[i])

        计算如果i天的时候卖出能获得的利润: profit = prices[i] - min_price

        更新 max_profit: max_profit = max(max_profit, profit)

  • 4. 代码实现

暴力枚举代码

def maxProfit(self, prices: List[int]) -> int:if not prices:return 0max_profit = 0for i in range(0, len(prices)-1):min_price = min(prices[0:i+1])max_price = max(prices[i+1:])if max_price - min_price > max_profit:max_profit = max_price - min_pricereturn max_profit

动态规划思路:

    def maxProfit(self, prices: List[int]) -> int:if not prices:return 0min_price = prices[0]max_profit = 0for i in range(1, len(prices)):if prices[i] < min_price:min_price = prices[i]profit = prices[i] - min_priceif profit > max_profit:max_profit = profitreturn max_profit

http://www.dtcms.com/a/563055.html

相关文章:

  • 网站可以做什么企业网站建设专家
  • 上海响应式网站开发深圳的网站建设公司哪家好
  • wordpress编辑富文seo推广有效果吗
  • 淮北论坛最新招聘信息网如何提升seo
  • 用dw做网站背景关于二手书的网站开发ppt
  • 企业品牌网站建设首选公司网站搭建修改收费依据
  • 河南企业建设网站网站建设的课件
  • 具有品牌的网站建设上海网站排名团队
  • 杭州科技网站作文库网站
  • 建站设计网站微信公众号的子菜单网页怎么制作
  • wordpress插件ssh东莞seo网络营销策划
  • 网站自然排名这么做微信小商店分销功能
  • 做钓鱼网站判刑中国建设人才服务信息网站
  • 网页设计公司平台凤山网站seo
  • 网站设计网络推广商贸平台公司手册制作网站
  • 电子商务网站建设对毕业设计搜索百度网页版
  • 鞋材加工东莞网站建设网站开发策划书怎么写
  • 韩国网站建站昆山制造网站的地方
  • 六安网站建设全包关于网站集约化建设公函
  • 校园门户网站建设实施方案小7手游官网下载
  • 广州做网站(信科网络)陇西做网站的公司
  • 苏州网站优化设计网络网站
  • 【RL】Scaling RL Compute for LLMs
  • 云软件网站建设个人网站后期怎么做企业
  • 网站联盟是什么意思wordpress注册没用
  • 光做网站推广咋样网站架设流程
  • 制作很好的网站做防水怎么注册网站
  • 9377 这种网站怎么做自己做一个app需要多少钱
  • 二级黄冈站跨境电商平台开发
  • 提供秦皇岛网站建设物联网是干什么的用的