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

郑州网站建设方案服务公司湖北省建设厅投标报名官方网站

郑州网站建设方案服务公司,湖北省建设厅投标报名官方网站,郑州博大泌尿外科医院,wordpress浮动窗口暴力法 这个方法在力扣平台上,提交运行后会超出时间限制 复杂度分析: 时间复杂度:O(N2)。空间复杂度:O(1)。 class Solution:def maxSubArray(self, nums):"""找到 nums 数组中子数组的最大和:param nums: 数组…

暴力法

这个方法在力扣平台上,提交运行后会超出时间限制

复杂度分析:

  • 时间复杂度:O(N2)。
  • 空间复杂度:O(1)。
class Solution:def maxSubArray(self, nums):"""找到 nums 数组中子数组的最大和:param nums: 数组:return: 最大子数组和"""size = len(nums)res = -float('inf')  # 初始化为负无穷for i in range(size):sum_val = 0for j in range(i, size):sum_val += nums[j]res = max(res, sum_val)return res

动态规划

算法的核心思想是 动态规划,通过状态压缩优化空间复杂度:

  1. 局部最大值(sub_max
    • 表示以当前元素结尾的子数组的最大和。
    • 如果前一个子数组的和 sub_max 是正数,则对当前元素有正增益,可以继续累加。
    • 如果前一个子数组的和 sub_max 是负数,则对当前元素是负增益,应该抛弃前面的结果,从当前元素重新开始计算。
  2. 全局最大值(max_sum
    • 记录遍历过程中所有局部最大值中的最大值。
    • 每次更新局部最大值后,都会更新全局最大值。

算法运行过程

假设输入 nums = [-2, 1, -3, 4, -1, 2, 1, -5, 4],算法的运行过程如下:

遍历元素 (nums[i])sub_max 更新逻辑sub_max 值max_sum 值
-2初始化-2-2
1sub_max = -2(负增益,抛弃)11
-3sub_max = 1(正增益,累加)-21
4sub_max = -2(负增益,抛弃)44
-1sub_max = 4(正增益,累加)34
2sub_max = 3(正增益,累加)55
1sub_max = 5(正增益,累加)66
-5sub_max = 6(正增益,累加)16
4sub_max = 1(正增益,累加)56

最终结果为 6

class Solution:def maxSubArray(self, nums):"""使用动态规划(状态压缩)找到 nums 数组中子数组的最大和:param nums: 数组:return: 最大子数组和"""if not nums:  # 如果数组为空,返回 0return 0max_sum = nums[0]  # 全局最大值,初始化为数组的第一个元素sub_max = nums[0]  # 局部最大值,初始化为数组的第一个元素for i in range(1, len(nums)):  # 从第二个元素开始遍历if sub_max > 0:# 前一个子组合最大值大于 0,正增益,继续累加sub_max += nums[i]else:# 前一个子组合最大值小于 0,负增益,抛弃前面的结果,从当前元素重新开始sub_max = nums[i]# 更新全局最大值max_sum = max(max_sum, sub_max)return max_sum  # 返回全局最大值

这两个 maxSubArray 实现都用于解决 最大子数组和 问题(即经典的「最大子段和」问题),但实现方式和效率有明显不同。


✅ 一、两种算法的本质区别

对比项暴力解法动态规划(Kadane 算法)
核心思想穷举所有可能的子数组,逐个求和并取最大值当前状态仅与上一个状态有关,动态转移
实现方式双重循环遍历所有子数组单次遍历 + 局部最优推导全局最优
代码结构两层 for 循环,维护当前子数组和一层 for 循环,维护一个局部最大和 sub_max
是否冗余是,有大量重复计算否,每个元素只处理一次

✅ 二、时间复杂度与空间复杂度对比

项目暴力解法动态规划(Kadane)
时间复杂度O(n²)O(n)
空间复杂度O(1)O(1)
  • 暴力解法:每个起点 i 都遍历一遍后续的所有子数组结尾 j,导致时间复杂度是平方级。

  • Kadane 算法:只需遍历一次数组,通过维护一个「以当前位置结尾的最大子数组和」,从而高效求解。


✅ 三、核心点解析

1. 暴力解法核心

  • 穷举所有可能的子数组。

  • 每次从下标 i 开始,向后累计和,取最大值。

  • 每个子数组和都要单独计算(冗余计算多)。

2. 动态规划核心(Kadane 算法)

  • 状态定义sub_max[i] 表示以 i 结尾的最大子数组和。

  • 状态转移方程

    sub_max[i] = max(nums[i], sub_max[i - 1] + nums[i])

    直观理解为:当前元素是从头开始一个新的子数组,还是继续累加前面的子数组更优。

  • 由于 sub_max[i] 只依赖于 sub_max[i-1],因此可进行状态压缩为一个变量,降低空间复杂度。


✅ 四、使用场景与选择建议

场景推荐算法原因
学习暴力法、理解问题暴力解法帮助理解子数组枚举方式
实际开发、面试中高频动态规划快速、高效,时间复杂度低

✅ 总结

维度暴力解法动态规划(Kadane)
时间复杂度O(n²)O(n)
空间复杂度O(1)O(1)
优点易理解高效、经典、面试常考
缺点慢,无法处理大规模输入初学者理解状态转移需一定抽象能力

👉 核心转化在于:从穷举所有可能,转为每一步只做一次决策,并记住最优解,避免重复计算。

http://www.dtcms.com/wzjs/608772.html

相关文章:

  • 地方网站wordpress 4.0
  • 江苏网站建设企业网站换域名seo怎么做
  • 网站建设就选网站推广可采用的方法有哪些
  • 网站建设工程师培训redis加速wordpress
  • 天津建设公司网站做动态文字的网站
  • 网站兼容工具景点介绍网站模板
  • 搭建网站赚钱吗西宁网站搭建企业
  • 做端口映射 怎么访问网站快手淘客网站是怎么做的
  • 制作微网站的费用国际贸易进口代理公司
  • 网站架构分析网站建设的难处
  • 潮州市网站建设wordpress国内免费模板
  • 网站开发公司的职责做本地房产网站
  • 学做网站从什么开始织梦的网站数据还原怎么做
  • 怎样保存网站资料做证据一般网站建设费用
  • 郑州企业网站托管公司有服务器数据库怎么安装wordpress
  • 百度自己网站排名好的广告片拍摄制作公司
  • 网站群建设 会议 主持中信建设有限责任公司深圳中信金融中心项目工期专业招标
  • 建设企业网站的原因南京seo关键词优化服务
  • 上海博大园林建设发展有限公司网站重庆商城网站开发
  • 重庆网站建设途锦科技网业截屏怎么截
  • 宝安网站建设方案外包app开发制作的基本
  • 龙岗公司做网站最近韩国电影片免费韩国在线观看
  • 网站理念微信网站设计尺寸
  • 网站服务费怎么做凭证网站链接怎么做跳转
  • 学校网站建设意义有哪些帮别人做买家秀的网站
  • 静态网站生成器怎样做随州网站建设价格
  • 怎样建立一个自己的网站动易网站安装子目录中
  • 免费教做面食的网站村网通为每个农村建设了网站
  • 推广网站怎么做知乎巨人科技网站建设
  • 男女做羞羞视频网站网站每年续费给谁