zoukankan      html  css  js  c++  java
  • 求连续的子数组的最大和

     //求子数组的最大和
            public static int maxSubarray(int[] a, int size)
            {
                if (size <= 0) Console.WriteLine("error array size");
                int sum = 0;
                int max = 0;
                int cur = 0;
                while (cur < size)
                {
                    sum += a[cur++];
                    if (sum > max)
                    {
                        max = sum;
                    }
                    else if (sum < 0)
                    {
                        sum = 0;
                    }
                }
                return max;

            }

            //求子数组的最大和
            static int Max(int[] array, int size)
            {
                int curSum = 0;
                int maxSum = 0;
                for (int i = 0; i < size; i++)
                {
                    curSum += array[i];
                    if (curSum < 0) curSum = 0;
                    if (curSum > maxSum) maxSum = curSum;

                }
                if (maxSum == 0)
                {            //若是数组中的元素均为负数,则输出里面的最大元素
                    maxSum = array[0];          //当然这步也可以写到上面一个循环里
                    for (int i = 1; i < size; i++)
                    {
                        if (maxSum < array[i]) maxSum = array[i];
                    }
                }
                return maxSum;
            }

  • 相关阅读:
    base64 web前端js解码与转码
    react常见组件问题Can't perform a React state update on an unmounted component
    Git详细的多人开发心得
    数组中filter方法配合字符串方法trim使用
    Ant Design实现表格搜索、分页、多选处理
    Ant Design中日期选择器的disabledDate用法
    react学习资源汇总
    react开发项目到上线全过程详解
    MySQL-5.6.30-linux-glibc2.5-x86_64.tar.gz 安装教程
    linux下配置mysql主从复制配置
  • 原文地址:https://www.cnblogs.com/dasydong/p/3280966.html
Copyright © 2011-2022 走看看