算法求解-最大和子序列问题(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。

相关推荐
暖馒6 小时前
Modbus应用层协议的深度剖析
网络·网络协议·c#·wpf·智能硬件
颜酱6 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
m0_736919107 小时前
C++代码风格检查工具
开发语言·c++·算法
yugi9878387 小时前
基于MATLAB强化学习的单智能体与多智能体路径规划算法
算法·matlab
DuHz7 小时前
超宽带脉冲无线电(Ultra Wideband Impulse Radio, UWB)简介
论文阅读·算法·汽车·信息与通信·信号处理
Polaris北极星少女7 小时前
TRSV优化2
算法
代码游侠8 小时前
C语言核心概念复习——网络协议与TCP/IP
linux·运维·服务器·网络·算法
2301_763472468 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
abluckyboy9 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法
园小异9 小时前
2026年技术面试完全指南:从算法到系统设计的实战突破
算法·面试·职场和发展