IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> LeetCode 53. 最大子数组和(最大子序和)——每日一练第6天(Java语言) -> 正文阅读

[数据结构与算法]LeetCode 53. 最大子数组和(最大子序和)——每日一练第6天(Java语言)

题目来源:最大子数组和——每日一练第6天(Java语言)
同时也是:LeetCode 53. 最大子数组和(最大子序和)


题目详情

给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。子数组是数组中的一个连续部分。

示例 1:

输入:nums = [-2,1,-3,4,-1,2,1,-5,4]
输出:6
解释:连续子数组 [4,-1,2,1] 的和最大,为 6 。

示例 2:

输入:nums = [1]
输出:1

示例 3:

输入:nums = [5,4,-1,7,8]
输出:23

提示:

1 <= nums.length <= 105
-104 <= nums[i] <= 104

进阶:如果你已经实现复杂度为 O(n) 的解法,尝试使用更为精妙的分治法求解。

解题思路

(一)暴力解法

排列所有的连续子数组,求出和,在所有的和中挨个比较,找到其最大的和。以nums = [5,4,-1,7,8]为例

步骤连续子数组连续子数组和
155
25、49
35、4、-18
45、4、-1、715
55、4、-1、7、823
644
74、-13
84、-1、710
94、-1、7、818
10-1-1
11-1、76
12-1、7、814
1377
147、815
1588

从上方表格中,可以显而易见,最大的连续子数组和为23。

(二)动态规划

我们在遍历数组的同时,去计算以nums[i]结尾的最大子序和,以nums = [5,4,-1,7,8]为例,用dp[i]表示nums中以nums[i]结尾的最大子序和。遍历数组:

inums[i]dp[i]dp[i] = max{dp[i-1]+nums[i] , nums[i]}
0nums[0] = 5dp[0] = 5只有一个子数组:5
1nums[1] = 4dp[1] = 9dp[0] + nums[1] = 9 , nums[1] = 5 ,则dp[1] = 9
2nums[2] = -1dp[2] = 8dp[1] + nums[2] = 8,nums[2] = -1,则dp[2] = 8
3nums[3] = 7dp[3] = 15dp[2] + nums[3] = 15,nums[3] = 7,则dp[3] = 15
4nums[4] = 8dp[4] = 23dp[3] + nums[4] = 23,nums[4] = 8 ,则dp[4] = 23

最后我们只需要在数组dp中,找到最大值,即为最大的子序和。

(三)贪心算法

遍历数组时,把每一位数字加起来,计算其和记为sum,并比较出最大值max

  • 如果sum<=0,说明保留这些数字,只会有负增益,所以需要舍弃之前的数字,重新开始计算,sum = nums[i]
  • 如果sum>0,说明保留这些数字,可以带来增益,所以保留这些数字,sum += nums[i]
    需要注意的是:如果数组中的所有数字都为负数的话,此时无论增加什么数字,只会带来负增益,所以此时的最大子数组和,就是这些负数中最大的那个负数。
inums[i]summax
0-2sum = -2-2
11-2 < 0,舍弃,sum = 1max{-2,1} = 1
2-31 > 0,保留,sum = -2max{1,-2} = 1
34-2 < 0,舍弃,sum = 4max{1,4} = 4
4-14 > 0,保留,sum = 3max{4,3} = 4
523 > 0,保留,sum = 5max{4,5} = 5
615 > 0 ,保留,sum = 6max{5,6} = 6
7-56 > 0,保留,sum = 1max{1,6} = 6
841 > 0,保留,sum = 5max{6,5} = 6

代码实现

(一)暴力解法

时间复杂度为O(n2),遇到数据量大的,很有可能会超时

class Solution {
    public int maxSubArray(int[] nums) {
        int max = Integer.MIN_VALUE;
        for(int i = 0 ; i < nums.length ; i++) {
            int sum = 0;
            for(int j = i ; j < nums.length ; j++) {
                sum +=nums[j];
                if(sum >= max) {
                    max = sum;
                }
            }
        }
        return max;
    }
}

(二)动态规划

时间复杂度为O(n)

class Solution {
    public int maxSubArray(int[] nums) {
        int len = nums.length;
        int[] dp = new int[len];
        dp[0] = nums[0];
        int max = dp[0];
        // [1,len-1]遍历数组
        for(int i = 1 ; i < len ; i++) {    
            int temp = dp[i-1] + nums[i];
            if(temp < nums[i] ) {
                dp[i] = nums[i];
            } else {
                dp[i] = temp;
            }
            // 在数组dp中,找最大值
            if(dp[i] > max) {
                max = dp[i];
            }
        }
        return max;
    }
}

(三)贪心算法

时间复杂度为:O(n)

class Solution {
    public int maxSubArray(int[] nums) {
        int len = nums.length;
        // 遍历数组,找出最大值
        int max_nums = Integer.MIN_VALUE;
        for(int i = 0 ; i < nums.length ; i++) {
            if(max_nums < nums[i]) {
                max_nums = nums[i];
            }
        }
        if(max_nums <= 0) {     // 特殊情况:nums中的又负数和0组成
            return max_nums;
        }
        int sum = 0;
        int max = nums[0];
        for(int i = 0 ; i < nums.length ; i++) {
            if(sum > 0) {
                sum += nums[i];
            } else {
                sum = nums[i];
            }
            max = Math.max(max,sum);
        }
        return max;
    }
}
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-12-15 18:33:00  更:2021-12-15 18:33:05 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 2:42:50-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码