最大子序列的和_子序列和最大值

最大子序列的和_子序列和最大值53. 最大子序和

大家好,又见面了,我是你们的朋友全栈君。

53. 最大子序和

https://leetcode-cn.com/problems/maximum-subarray/description/

package com.test;

import java.util.ArrayList;
import java.util.List;

/**
 * @Author stono
 * @Date 2018/8/21 上午10:56
 */
public class Lesson053 {
    public static void main(String[] args) {
        //int[] nums = {-2,1,-3,4,-1,2,1,-5,4};
        int[] nums = {-2,-1};
        int max = maxSubArray(nums);
        System.out.println(max);
    }
    public static int maxSubArray(int[] nums) {
        // 存放最大序列和
        int max = 0;
        int sum = 0;
        for (int i = 0; i < nums.length; i++) {
            int num = nums[i];
            // 如果num出现负值,序列和就会下降,先存一份序列和
            if(num<0 && i>0){
                max = sum>max?sum:max;
            }
            // 第一个值就小于0,先把第一个值存起来
            if (num < 0 && i == 0) {
                max = num;
            }
            // 如果序列和小于0,就清空一下重新开始累加;
            if (sum < 0) {
                sum = 0;
            }
            sum = sum + num;
            // 每次判断一下,存储最大max
            max = sum>max?sum:max;
        }
        return max;
    }
}

还是有别的方法:

最大子序列的和_子序列和最大值

 仿python的java:

class Solution {
    public int maxSubArray(int[] nums) {
        // 最大值
        int max = nums[0];
        // 最大值缓存列表
        List<Integer> maxList = new ArrayList<>(8);
        // 先把第一个值加进入
        maxList.add(max);
        for (int i = 1; i < nums.length; i++) {
            // 再依次往里面加值
            maxList.add(nums[i]);
            // 如果之前的那个值大于0,就进行累加
            if (maxList.get(i-1) > 0) {
                maxList.set(i , maxList.get(i) + maxList.get(i - 1));
            }
            // 如果累加的结果大于max,就更换max的值
            if (maxList.get(i) > max) {
                max = maxList.get(i);
            }
        }
        return max;
    }
}

 动态规划:

转移条件是 逐项求和以后如果没有变大就重新开始

已通过

最大子序列的和_子序列和最大值

分治:

1 分成两部分,计算左边,右边和中间(包含中间元素的连续子集)的最大值

2 取三个中的最大

最大子序列的和_子序列和最大值

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/107354.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月20日 下午1:40
下一篇 2022年4月20日 下午1:40


相关推荐

  • 在线快速将pdf转换成word[通俗易懂]

    在线快速将pdf转换成word[通俗易懂]在线快速将pdf转换成word处理同样1000个PDF文件的格式转换,在线PDF转换成Word转换器比普通PDF转换器快8-12倍以上,是一款全自动化的转换模式,为用户提供了高质量的PDF转换服务的同时,大大节省了转换过程中所消耗的时间。今天小编给你支招的这款pdf转换成word转换器在线是专业转换网站,能够给你多种格式转换的选择。  相对于电脑版PDF转换器而言,近期

    2022年5月2日
    38
  • Glassfish4.1安装及配置[通俗易懂]

    Glassfish4.1安装及配置[通俗易懂]安装及配置下载及安装详情见官网。关于文档上述下载的GlassFish为开源版本,文档见GlassFishServerDocumentation。不过,在使用中发现该文档的参数并不全,比如,ReferenceManual中提供了命令create-auth-realm用来手动创建realm,现在要设定realm所在的domain,却没有找到相应的参数。反倒是在GlassFish商业版SunG

    2022年8月20日
    7
  • case when oracle mysql_Mysql oracle casewhen 完美应用

    case when oracle mysql_Mysql oracle casewhen 完美应用使用SQL99标准通用语法中的case表达式,将职位是分析员的,工资+1000;职位是经理的,工资+800;职位是其它的,工资+4001;case字段when条件1then表达式1when条件2then表达式2else表达式nendselectename”姓名”,job”职位”,sal”涨前工资”,casejobwhen‘ANALYST‘thensal+1000wh…

    2025年9月20日
    10
  • android jword.zip,Android 项目打包到 JCenter 的坑

    android jword.zip,Android 项目打包到 JCenter 的坑搜索下如何发布 Android 项目的信息 大部分都会找到这篇文章 PublishingGr 中文的指引可以看使用 Gradle 发布项目到 JCenter 仓库 不过 如果按照这些文章提供的 build gradle 可能还会遇到一些坑 调用 getBootClass 出错具体的错误信息是 Cannotca

    2026年3月17日
    2
  • 在tcp协议的三次握手中(tcp/ip协议三次握手)

    TCP特性1.确认应答(可靠传输的最核心机制)1.确认应答(可靠传输的最核心机制)可靠传输的最核心机制

    2022年4月10日
    68
  • Opcode指令解析

    Opcode指令解析2 1 实模式 保护模式 以及虚拟 8086 模式指令格式 Intel 64 和 IA 32 架构指令编码是图 2 1 所示格式的子集 一条指令包括可选的指令前缀 顺序任意 主操作码 最多 3 字节 由 ModR M 和 SIB 字节 可选 组成的地址格式描述符 如果需要的话 偏移量 可选 以及立即数 可选 前缀 主操作码

    2026年3月20日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号