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;
}
相关推荐
代码游侠7 分钟前
C语言核心概念复习——网络协议与TCP/IP
linux·运维·服务器·网络·算法
2301_7634724617 分钟前
C++20概念(Concepts)入门指南
开发语言·c++·算法
abluckyboy1 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法
园小异1 小时前
2026年技术面试完全指南:从算法到系统设计的实战突破
算法·面试·职场和发展
m0_706653231 小时前
分布式系统安全通信
开发语言·c++·算法
天天爱吃肉82182 小时前
跟着创意天才周杰伦学新能源汽车研发测试!3年从工程师到领域专家的成长秘籍!
数据库·python·算法·分类·汽车
alphaTao2 小时前
LeetCode 每日一题 2026/2/2-2026/2/8
算法·leetcode
甄心爱学习2 小时前
【leetcode】判断平衡二叉树
python·算法·leetcode
颜酱2 小时前
从二叉树到衍生结构:5种高频树结构原理+解析
javascript·后端·算法
不知名XL3 小时前
day50 单调栈
数据结构·算法·leetcode