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

【leetcode hot 100 53】最大子数组和

解法一:(动态规划)我们用 f(i) 代表以第 i 个数结尾的「连续子数组的最大和」,那么很显然我们要求的答案就是:max{f(i)},f(i)=max{f(i−1)+nums[i],nums[i]}

class Solution {
    public int maxSubArray(int[] nums) {
        int pre=0, max_sum=nums[0], left=0;
        while(left<nums.length){
            pre=Math.max(pre+nums[left],nums[left]);
            max_sum=Math.max(max_sum,pre);
            left++;
        }
        return max_sum;
    }
}

注意:

  • ‌动态规划通过将一个大问题分解为多个重叠的子问题,并存储子问题的解以避免重复计算,从而提高算法效率。其核心思想在于“分解问题、缓存中间结果,避免重复计算,从而高效求解复杂问题”‌

相关文章:

  • 1278. 分割回文串 III
  • Docker安装Grafana数据可视化平台
  • Linux-计算机网络.udp
  • SQL Server下载和安装细节
  • 【慕课网wiki项目学习笔记01】Spring Boot 项目搭建
  • 使用vite创建vue3项目
  • 消息队列与RocketMQ
  • linux离线安装miniconda环境
  • 如何将本地项目提交到 GitHub
  • 登录服务器后如何找到对应的drupal所在的文件夹
  • FPGA-DE2115开发板实现4位全加器、3-8译码器。
  • Ribbon实现原理
  • 清华DeepSeek深度探索与进阶指南
  • 扫描纸质文件转pdf---少页数+手机+电脑协作
  • 01. HarmonyOS应用开发实践与技术解析
  • 2025-3-3 二叉树的存储结构
  • Makefile
  • 【Java EE】JavaEE导读,探寻 JavaEE:解锁企业级开发的璀璨密码与进阶指南
  • 论文学习——The Hilti SLAM Challenge Dataset
  • iOS逆向工程概述与学习路线图
  • 司法部:持续规范行政执法行为,加快制定行政执法监督条例
  • 博裕基金拟收购“全球店王”北京SKP最多45%股权
  • 外卖大战之外,缝隙中的校园到寝外卖和那些送餐的大学生们
  • 黔西市游船倾覆事故发生后,贵州省气象局进入特别工作状态
  • 德国斯图加特发生车辆冲撞人群事件,至少三人受伤
  • 科普|“小石头,大麻烦”,出现输尿管结石如何应对?