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

最大子序列的和_子序列和最大值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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 第十七届全国大学智能汽车竞赛竞速比赛规则

    第十七届全国大学智能汽车竞赛竞速比赛规则 §00规则导读参加过往届比赛的队员可以通过下面内容了解第十七届竞赛规则主要变化。如果第一次参加比赛,建议对于本文进行全文阅读。 §01前言

    2022年5月30日
    74
  • 多线程案例:生产者和消费者

    多线程案例:生产者和消费者

    2021年5月6日
    118
  • 大型视频监控存储方式_私人云存储解决方案

    大型视频监控存储方式_私人云存储解决方案一、背景描述在建设和谐社会的环境下,国家对很多单位的视频监控系统提出了更高的要求,要求他们把视频监控录像保存更长的时间,要求视频监控的画面更加清晰一点;这些要求的提出,导致原有视频监控系统的存储空间不能满足最新的需求,需要一个更大的存储空间来保存视频录像,如何给原有的监控系统进行存储空间的扩容,以及如何满足将来进一步扩容的需求,正在成为系统集成商和客户的难题。AXUS公司针对中国市场进行了一…

    2022年10月7日
    0
  • 苹果 find my 原理_find区别

    苹果 find my 原理_find区别什么是查我网络?2021年4月21日的苹果发布会发布了一款新的产品:AirTag,防丢器。使用的是BLE+UWB的技术。BLE通过FindMy网络解决了GPS定位的问题;而UWB解决了室内的、厘米级的精准定位问题。二者相互补充,实现了比较精准的定位,为用户提供优秀的物品防丢体验。查我网络(FindMyNetwork)是苹果公司发布的一项应用技术。这项技术比较神奇的一点是,支持这项技术的苹果设备(iPhone,iPad,AirPods,AirTag等),即使本身没有GPS

    2022年10月22日
    0
  • RPC协议及常用框架

    RPC协议及常用框架https://www.jianshu.com/p/8ba4b7b834aaRPC协议RPC:远程过程调用,原则上来说系统间跨进程的调用都属于RPC范畴RMI/HTTP/dubbo/SpringCloud/thriftRPC框架如何实现分布式环境下的远程调用在一个典型的RPC的使用场景中,包含了服务发现,负载,容错,网络传输,序列化等组件,其中RPC协议指明了程序如何进行网络传输和序列化。RPC协议的组成RPC协议的组成1.地址:服务提供者地址2.端口:.

    2022年5月12日
    43
  • android跨平台开发_手机游戏跨平台开发

    android跨平台开发_手机游戏跨平台开发安卓跨平台开发实践

    2022年4月21日
    36

发表回复

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

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