XTU-OJ 1169-最大子段和

题目描述

给你一个数列a1,a2,...,an,求m个连续数字组成的子段和最大值。

输入

有多个样例,每个样例的第一行是两个整数n和m,(1≤m≤n;≤100,000)。如果n和m为0表示输入结束,这个样例不需要处理。第二行是n个整数ai,0≤ai≤10000。

输出

每行输出一个整数,即样例的结果。

样例输入
复制代码
6 3
1 2 3 4 5 6
6 3 
1 2 3 3 2 1
0 0
样例输出
复制代码
15
8

解题思路: 前缀和 (之前的博客解释过了,听起来高大上,实际上就是个弟中之弟)

AC代码:

cpp 复制代码
#include <stdio.h>

int main()
{
    int n,m,t,ans;
    while (scanf("%d %d",&n,&m) != EOF && !(n==0 && m==0))
    {
        int nums[100010] = {0};
        for (int i = 1; i <= n; i ++)
        {
            scanf("%d",&nums[i]);
            nums[i] += nums[i-1];               // 前缀和
        }
        ans = nums[m];
        for (int i = m+1; i <= n; i ++)
        {
            t = nums[i]-nums[i-m];
            if (t > ans)
                ans = t;
        }
        printf("%d\n",ans);
    }
    return 0;
}
相关推荐
hsling松子1 小时前
使用PaddleHub智能生成,献上浓情国庆福
人工智能·算法·机器学习·语言模型·paddlepaddle
dengqingrui1232 小时前
【树形DP】AT_dp_p Independent Set 题解
c++·学习·算法·深度优先·图论·dp
C++忠实粉丝2 小时前
前缀和(8)_矩阵区域和
数据结构·c++·线性代数·算法·矩阵
ZZZ_O^O2 小时前
二分查找算法——寻找旋转排序数组中的最小值&点名
数据结构·c++·学习·算法·二叉树
CV-King3 小时前
opencv实战项目(三十):使用傅里叶变换进行图像边缘检测
人工智能·opencv·算法·计算机视觉
代码雕刻家3 小时前
数据结构-3.9.栈在递归中的应用
c语言·数据结构·算法
雨中rain3 小时前
算法 | 位运算(哈希思想)
算法
Kalika0-05 小时前
猴子吃桃-C语言
c语言·开发语言·数据结构·算法
代码雕刻家5 小时前
课设实验-数据结构-单链表-文教文化用品品牌
c语言·开发语言·数据结构
sp_fyf_20245 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-02
人工智能·神经网络·算法·计算机视觉·语言模型·自然语言处理·数据挖掘