直接上代码吧:

情况一:全部是非负数整数的时候,其实非负实数处理也一样。

package Person;

import java.util.Scanner;

public class Main
{
    public static final int maxn = 105;
    public static int[] Arr = new int[maxn];
    public static void main(String[] args)
    {
        int N;
        Scanner cin = new Scanner(System.in);
        N = cin.nextInt();
        for(int i = 0 ; i < N ; i++)
        {
            Arr[i] = cin.nextInt();
        }
        int thissum,maxsum;
        thissum = maxsum = 0;
        for(int i = 0 ; i < N ; i++)
        {
            thissum += Arr[i];//向右累加
            if(thissum > maxsum)
            {
                maxsum = thissum;//更新最大值
            }
            else if(thissum < 0)
            {
                thissum = 0;//若是小于零,则不可能是后面的部分和增大,抛弃它。
            }
        }
        System.out.println(maxsum);
    }
}

情况二:不确定里边的数是啥类型的。

从以下方面入手:

1.遍历一遍数组,如果全部是负数的时候,找出最大的负数,并把它输出来,结束程序,否则,进到下面的步骤。

2.思路和上面的一样。

代码实现如下:(假设所有的数均为整数)

package Person;

import java.util.Scanner;

public class Main
{
    public static final int maxn = 105;
    public static int[] Arr = new int[maxn];
    public static void main(String[] args)
    {
        int N;
        Scanner cin = new Scanner(System.in);
        N = cin.nextInt();
        int Max = 0;
        for(int i = 0 ; i < N ; i++)
        {
            Arr[i] = cin.nextInt();
            if(i == 0)
            {
                Max = Arr[i];
            }
            else
            {
                Max = Math.max(Max,Arr[i]);
            }
        }
        if(Max < 0)
        {
            System.out.println(Max);
            return;
        }

  //这个是分水岭。
        int thissum,maxsum;
        thissum = maxsum = 0;
        for(int i = 0 ; i < N ; i++)
        {
            thissum += Arr[i];//向右累加
            if(thissum > maxsum)
            {
                maxsum = thissum;//更新最大值
            }
            else if(thissum < 0)
            {
                thissum = 0;//若是小于零,则不可能是后面的部分和增大,抛弃它。
            }
        }
        System.out.println(maxsum);
    }
}

代码其实很简单的,如果有不明白的,随时可以留言,24小时在线,谢谢呀

java.——最大子序列和(前提是:全部都是非负数)的更多相关文章

  1. Caused by:java.sql.SQLException:ORA-01008:并非所有变量都已绑定

    1.错误描述 Caused by:java.sql.SQLException:ORA-01008:并非所有变量都已绑定 2.错误原因 3.解决办法

  2. java中POJO类和DTO类都要实现序列化

    java中POJO类和DTO类都要实现序列化 java中POJO类和DTO类都要实现序列化 java中POJO类和DTO类都要实现序列化 序列化:序列化是将对象转换为容易传输的格式的过程.例如,可以序 ...

  3. 初学者学Java常遇到的问题,我都给你回答了!

    前言 只有光头才能变强. 文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y 春节在家刷知乎,看到了一个知乎的问题:<学 ...

  4. 11个简单的Java性能调优技巧,傻瓜都能学会!

    大多数开发人员理所当然地以为性能优化很复杂,需要大量的经验和知识.好吧,不能说这是完全错误的.优化应用程序以获得最佳性能不是一件容易的事情.但是,这并不意味着如果你不具备这些知识,就不能做任何事情. ...

  5. java编程思想(2)--一切都是对象

    1创建对象 String s ;创建引用,并未初始化,即引用未关联任何东西 String s2="asda"; 初始化 System.out.println(s2); System ...

  6. Java编程思想(二)一切都是对象

    2.1用句柄操纵对象 尽管一切都看作是对象,但是操纵的标识符实际上是指向一个对象的“句柄”(handdle): 拥有一个句柄并不表示必须有一个对象同他连接: String  s:   这里创建的只是句 ...

  7. [Effective Java]第三章 对所有对象都通用的方法

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  8. java多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么?

    多线程有两种实现方法,分别是继承Thread类与实现Runnable接口 同步的实现方面有两种,分别是synchronized,wait与notify 先看一下java线程运行时各个阶段的运行状态 j ...

  9. 初读"Thinking in Java"读书笔记之第二章 --- 一切都是对象

    用引用操纵对象 Java里一切都被视为对象,通过操纵对象的一个"引用"来操纵对象. 例如, 可以将遥控器视为引用,电视机视为对象. 创建一个引用,不一定需要有一个对象与之关联,但此 ...

随机推荐

  1. Qt Quick Dialogs

    一.如下图.. 二. 1.FileDialog //定义FileDialog{ id:fileDialog; title: "open a picture"; nameFilter ...

  2. SpringBoot 使用Druid连接池

    1.pom依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId> ...

  3. LightOJ 1027 A Dangerous Maze(期望)题解

    题意:n扇门,每扇门后都有一个值x,如果x<0会让你等待-x再重新回到这里选择门,x>0你经过x时间就会被传送走,问你被传送走的期望 思路:假设被传送走的期望为E,那么对于x<0来说 ...

  4. 【学习】Hall’s Marriage Theorem

    其实是在做题时遇到这个定理的. 这个定理的图论意义是: 对于一个二分图\(G=\{X+Y,E\}\),它满足: \(\forall W \subseteq X, \, |W| \leq |N_G(W) ...

  5. What are the differences between Flyweight and Object Pool patterns?

    What are the differences between Flyweight and Object Pool patterns? They differ in the way they are ...

  6. 【配置详解】Quartz配置文件详解

    我们通常是通过quartz.properties属性配置文件(默认情况下均使用该文件)结合StdSchedulerFactory 来使用Quartz的.StdSchedulerFactory 会加载属 ...

  7. oracle单行函数 之 字符函数

    Upper(字符串 / 列):将输入的字符串变成大写 Lower(字符串 / 列):将输入的字符串变成小写 Initcap(字符串 / 列):开头首字母大写 Length(字符串 / 列):字符串长度 ...

  8. 分布式强化学习基础概念(Distributional RL )

    分布式强化学习基础概念(Distributional RL) from: https://mtomassoli.github.io/2017/12/08/distributional_rl/ 1. Q ...

  9. JZ2440之GPIO篇

    买来开发板已经有一段时间了,刚接触时兴奋至极,后来跟着视频看下去发现似乎自己并没有学到太多东西,于是发现自己可能欠缺的太多以致从课程中无法提取出重要的东西来,所以并没有得到太多的营养成分.因此我个人认 ...

  10. Anaconda使用命令

    参考的地址:https://zhuanlan.zhihu.com/p/32925500 conda 基础命令: 1.验证conda已被安装 conda --version 终端上就会以conda 版本 ...