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

代码随想录算法训练营第二十八天 | 买卖股票的最佳实际、跳跃游戏、K次取反后最大化的数组和

买卖股票的最佳时机:

        这里可以得到当有利润就会卖出得到当前的股票,然后就是向后移动一位就可以了,判断卖出那天买入,后一天卖出会不会有收益,有收益就加上,因为同一天的买入和卖出相当于没有操作,因此逻辑性不变,详细代码如下所示:

class Solution(object):def maxProfit(self, prices):""":type prices: List[int]:rtype: int"""if len(prices) <=1:return 0count = 0pre = 0cur = 1while(pre<len(prices)-1):if prices[cur] - prices[pre] > 0:count += prices[cur] - prices[pre]pre+=1cur+=1return count

跳跃游戏

        这里的思路是不断更新覆盖范围,看覆盖大小是不是一在更新,如果说覆盖范围到达最后的元素,那么符合,但是如果到了覆盖范围的最后一个还没有到达目的地,那么就不可行,直接返回False,详细代码如下所示:

class Solution(object):def canJump(self, nums):""":type nums: List[int]:rtype: bool"""if len(nums)<=1:return Truecover = 0index = 0while(index<=cover):cover = max(cover,nums[index]+index)if cover >= len(nums) - 1:return Trueindex+=1return False

K次取反后最大化的数组和

        思路如下,我觉得还是比较好的:

        1.​​预处理排序​​:先排序,再按策略翻转,避免重复计算最小值。
        2.​​优先处理负数​​:先翻转所有负数(因为翻转负数能直接增加总和)。
        3.​​剩余次数的数学处理​​:若剩余翻转次数 k 为奇数,只需翻转当前最小元素一次。

详细代码如下所示:

class Solution(object):def largestSumAfterKNegations(self, nums, k):nums.sort()  # 排序,O(n log n)# 第一阶段:优先翻转所有负数for i in range(len(nums)):if nums[i] < 0 and k > 0:nums[i] = -nums[i]k -= 1# 第二阶段:若剩余k为奇数,翻转当前最小元素(可能是0)if k % 2 == 1:nums.sort()  # 重新排序找到最小值nums[0] = -nums[0]return sum(nums)  # 总和计算,O(n)

        由于浏览器清空内存之后,原有代码会消失,因此此处链接放的是代码随想录的链接。

http://www.xdnf.cn/news/19901.html

相关文章:

  • Vue基础知识-脚手架开发-初始化目录解析
  • 分布式对象存储系统 Minio 之 Centos 环境安装
  • SQLynx 3.7 发布:数据库管理工具的性能与交互双重进化
  • Java 方法:从定义调用到重载,入门到面试全攻略
  • 前端路由切换不再白屏:React/Vue 实战优化全攻略(含可运行 Demo)
  • 基于html+css+js+jquery实现轮播图(自动轮播,手动选择,翻页)
  • #T1359. 围成面积
  • 华清远见25072班I/O学习day5
  • 嵌入式硬件 - 51单片机3
  • NotePad++下载安装与设置
  • 使用a标签跳转之后,会刷新一次,这个a标签添加的样式就会消失
  • 搞懂IFNULL 和 NULLIF
  • 【C++详解】异常概念、抛出捕获与处理机制全解析
  • 一文读懂数据分类分级:企业安全治理的基石
  • 深入理解Linux进程信号机制
  • 残差神经网络的案例
  • 【面试题】LangChain与LlamaIndex核心概念详解
  • 聚焦GISBox矢量服务:数据管理、数据库连接与框架预览全攻略
  • 分布式电源接入电网进行潮流计算
  • Linux笔记---UDP套接字实战:简易聊天室
  • 服务器不支持node.js16以上版本安装?用Docker轻松部署Node.js 20+环境运行Strapi项目
  • 新规则,新游戏:AI时代下的战略重构与商业实践
  • 安全领域必须关注每年发布一次“最危险的25种软件弱点”清单 —— CWE Top 25(内附2024 CWE Top 25清单详情)
  • Boost搜索引擎 数据清洗与去标签(1)
  • 【OpenHarmony文件管理子系统】文件访问接口mod_fs解析
  • ECMAScript(2)核心语法课件(Node.js/React 环境)
  • uniapp的上拉加载H5和小程序
  • PDF.AI-与你的PDF文档对话
  • C++虚函数虚析构函数纯虚函数的使用说明和理解
  • redisson延迟队列报错Sync methods can‘t be invoked from async_rx_reactive listeners