算法求解-最大和子序列问题(C#)

1、算法目标:

题目描述

设数组a是有n个元素的整数数组,如何从中找出最大和子序列的和?

输入

第一行输入n

第二行输入n个数

输出

输出最大和子序列的和

样例输入

4

2 -1 3 -4

样例输出

4

2、算法实现:

csharp 复制代码
using System;

class Program
{
    static void Main()
    {
        // 读取输入
        int n = int.Parse(Console.ReadLine());
        string[] input = Console.ReadLine().Split();
        int[] array = new int[n];
        
        for (int i = 0; i < n; i++)
        {
            array[i] = int.Parse(input[i]);
        }

        // 使用 Kadane 算法找到最大和子序列
        int maxSoFar = int.MinValue;
        int maxEndingHere = 0;

        for (int i = 0; i < n; i++)
        {
            maxEndingHere += array[i];

            if (maxSoFar < maxEndingHere)
            {
                maxSoFar = maxEndingHere;
            }

            if (maxEndingHere < 0)
            {
                maxEndingHere = 0;
            }
        }

        // 输出结果
        Console.WriteLine(maxSoFar);
    }
}

3、代码解释

读取输入:

第一行读取数组的长度 n。

第二行读取 n 个整数,并将其存储在数组 array 中。
初始化变量:

maxSoFar 用于存储到目前为止找到的最大和,初始值为 int.MinValue,表示最小的整数。

maxEndingHere 用于存储当前子序列的和,初始值为 0。
遍历数组:

对于每个元素,将其加到 maxEndingHere 上。

如果 maxEndingHere 大于 maxSoFar,则更新 maxSoFar。

如果 maxEndingHere 小于 0,则重置 maxEndingHere 为 0,因为负数会降低后续子序列的和。
输出结果:

最后输出 maxSoFar,即最大和子序列的和。

样例输入输出

对于样例输入:

csharp 复制代码
4
2 -1 3 -4

程序的输出:

csharp 复制代码
4

这是因为最大和子序列是 [2, -1, 3],其和为 4。

相关推荐
HXhlx1 小时前
CART决策树基本原理
算法·机器学习
Wect2 小时前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript
颜酱3 小时前
单调队列:滑动窗口极值问题的最优解(通用模板版)
javascript·后端·算法
Gorway9 小时前
解析残差网络 (ResNet)
算法
拖拉斯旋风9 小时前
LeetCode 经典算法题解析:优先队列与广度优先搜索的巧妙应用
算法
Wect9 小时前
LeetCode 207. 课程表:两种解法(BFS+DFS)详细解析
前端·算法·typescript
灵感__idea1 天前
Hello 算法:众里寻她千“百度”
前端·javascript·算法
Wect1 天前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
NAGNIP2 天前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
Scout-leaf2 天前
WPF新手村教程(三)—— 路由事件
c#·wpf