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;
}
相关推荐
大白的编程日记.19 小时前
【高阶数据结构学习笔记】高阶数据结构之B树B+树B*树
数据结构·笔记·学习
Kt&Rs19 小时前
11.9 LeetCode 题目汇总与解题思路
算法·leetcode
ゞ 正在缓冲99%…20 小时前
leetcode1547.切棍子的最小成本
数据结构·算法·leetcode·动态规划
2401_8414956420 小时前
【LeetCode刷题】移动零
数据结构·python·算法·leetcode·数组·双指针法·移动零
开心星人20 小时前
Leetcode hot100 Java刷题(二)
java·算法·leetcode
hn小菜鸡21 小时前
LeetCode 153.寻找旋转排序数组中的最小值
数据结构·算法·leetcode
DeniuHe21 小时前
逻辑回归(Logistic Regression)详细解释与公式推导
算法·机器学习·逻辑回归
迅量科技资讯分享21 小时前
手机拍照明晰度评估:传感器尺寸像素数量与处理器算法解析
算法·三星·像素
liu****21 小时前
12.线程同步与互斥
linux·数据结构·c++·算法·1024程序员节
麦烤楽鸡翅21 小时前
小红书推荐系统(牛客)
java·python·算法·秋招·春招·牛客·面试算法题