JAVA算法练习题day11

普通数组

13.最大子数组和

通过这题复习了动态规划4部曲。同时发现自己推导DP递推式时候的致命错误,累积了分析经验。

java 复制代码
class Solution {
    public int maxSubArray(int[] nums) {
        //因为是求最大和的连续子数组。上一个状态(sum0)将影响到下一个状态的结果,动态规划
        //DP四部曲:DP数组的含义(数组本身以及下标),确定DP数组的递推式,DP数组初始化,确定遍历顺序,最后手动模拟DP数组
        //含义:DP[i]:以下标i为**结尾**的为某个连续子数组的最大和
        //递推式 dp[i] = max(dp[i-1],dp[i-1]+nums[i]) 不对,没有抓紧DP的含义。
        //针对每个位置,因为DP数组的含义,该位置的数字一定是要的,所以两种情况,1.要之前的和,2.不要之前的和。二者分别加上该数,取最大就好。
        int[] dp = new int[nums.length];
        int ans = 0;
        dp[0] = nums[0];
        ans = dp[0];
        for(int i = 1 ;i <nums.length ; i++){
            dp[i] =  Math.max(dp[i-1]+nums[i],nums[i]);
            ans = Math.max(dp[i],ans);
        }
        return ans;
    }
}

前缀和+贪心

复习前缀和:

图片来自"灵茶山艾府"[https://leetcode.cn/problems/range-sum-query-immutable/solutions/2693498/qian-zhui-he-ji-qi-kuo-zhan-fu-ti-dan-py-vaar/\]

前缀和+贪心似乎把题目弄复杂了(对我来说更难理解此做法),就不研究了。

Python:

python 复制代码
class Solution(object):
    def maxSubArray(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        #python的语法真的奇怪,我还得多学,现在只是看得懂代码,但是写不出来
        dp = [0] * len(nums)
        dp[0] = nums[0]
        
        for i in range(1,len(nums)):
            dp[i] = max(nums[i],nums[i]+dp[i-1])
            dp[0] = max(dp[i],dp[0])
        return dp[0]
相关推荐
云栖梦泽18 小时前
易语言界面美化与组件扩展
开发语言
catchadmin18 小时前
PHP 值对象实战指南:避免原始类型偏执
android·开发语言·php
_Minato_18 小时前
数据结构知识整理——复杂度的计算
数据结构·经验分享·笔记·算法·软考
listhi52018 小时前
针对燃油运输和车辆调度问题的蚁群算法MATLAB实现
前端·算法·matlab
Trouville0118 小时前
Python中encode和decode的用法详解
开发语言·python
是梦终空18 小时前
JAVA毕业设计259—基于Java+Springboot+vue3工单管理系统的设计与实现(源代码+数据库+开题报告)
java·spring boot·vue·毕业设计·课程设计·工单管理系统·源代码
JS_GGbond18 小时前
JavaScript事件循环:餐厅里的“宏任务”与“微任务”
开发语言·javascript·ecmascript
用户21903265273519 小时前
Spring Boot 集成 Redis 实现看门狗 Lua 脚本分布式锁
java·后端
zybsjn19 小时前
ShardingSphere 启动报错 “Unknown table ‘keywords‘ in information_schema“ 完整解决方案
java
月明长歌19 小时前
【码道初阶】【LeetCode 102】二叉树层序遍历:如何利用队列实现“一层一层切蛋糕”?
java·数据结构·算法·leetcode·职场和发展·队列