zoukankan      html  css  js  c++  java
  • 02数组

    1、题目要求:

            a、输入一个整数数组,数组里有正数也有负数。

            b、数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。

            c、求所有子数组的和的最大值。

     2、思路构想:

       求数组中的一个元素(a)和上一个元素(b)的和(c),将 a 和 c 进行比较,若 c > a ,则用 c 代替 a 的值,此操作遍历整个数组,此时最大子数组的和就会被保存在数组中的某一个位置。最后再次遍历数组,求得最大子数组的和。

          3、思路构想的代码解释:

    1、通过用户输入数组容量,随机产生一个整型数组

    2、通过循环遍历所有元素求出以该元素为首节点的所有子数组的和,将其存入一个list中

    3、求出list的最大值

    public static int getResult(ArrayList<Integer> array) {

            int sum = 0;

            int result = array.get(0);

            for (Integer integer : array) {

                if(sum<=0)

                    sum = integer;

                else

                    sum += integer;

                if(sum>result)

                    result = sum;

            }

            return result;

        }

  • 相关阅读:
    工欲善其事,必先利其器
    年度总结
    人脸解锁从底层到上层(一)
    Hexo NexT 主题添加评论和文章阅读量
    摄影历程-第一章
    西藏之旅
    软件测试和评估
    WordCount优化
    WordCount编码与测试
    值得深入思考的五个问题
  • 原文地址:https://www.cnblogs.com/--lzx1--/p/13237838.html
Copyright © 2011-2022 走看看