Fork me on Gitee

前缀和应用

 最大和

★   输入文件:maxsum.in   输出文件:maxsum.out   简单对比
时间限制:1 s   内存限制:128 MB
【题目描述】

N个数围成一圈,要求从中选择若干个连续的数(注意每个数最多只能选一次)加起来,问能形成的最大的和。

【输入格式】

第一行输入N,表示数字的个数,第二行输入这N个数字。

【输出格式】

输出最大和。

【样例输入】
8
2 -4 6 -1 -4 8 -1 3
【样例输出】
14
【提示】
40%  1<=N<=300

60%  1<=N<=2000

100%  1<= N<=100000,答案在longint范围内。

解法:

1. 构成环,无非两种情况:前缀和之差  总和减去前缀和之差

2. 维护一个最大值 一个最小值  结果ans 为循环链中的最大值的

 

import java.util.Arrays;
import java.util.Scanner;

public class S1 {

    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int N = in.nextInt();

        int[] sum = new int[10000];
        for (int i = 1; i <= N; i++) {
            sum[i] = sum[i - 1] + in.nextInt();
        }
        int maxi = sum[N];
        int mini = sum[N];
        int ans = 0;
        for (int j = N-1; j>=1; j--) {
            ans = Math.max(ans, Math.max(maxi - sum[j], sum[j] + sum[N] - mini));
            maxi = Math.max(maxi, sum[j]);
            mini = Math.min(mini, sum[j]);
        }
        System.out.println(ans);

    }

}

 

连续和

题目描述:
给定n个数 a1 , a2 , … , an
定义 fi,j = ai + ai+1 + ai+2 + … + aj-1 + aj (1 ≤ i ≤ j ≤ n)
求 fi,j 的最大值
输入描述:
第一行有1个数,n
第二行有n个数,a1 , a2 , … , an
输出描述 Output Description
输出只有一行,fi,j 的最大值
样例输入:
7
3 6 -8 9 -12 1 2
样例输出 Sample Output
10
数据范围及提示:
样例中当 i = 1 , j = 4 时,fi,j = a1 + a2 + a3 + a4 = 3 + 6 - 8 + 9 = 10 为最大值
数据规模:
10%的数据 n = 7
30%的数据 n ≤ 1000
100%的数据 n ≤ 1000000 -1000 ≤ ai ≤ 1000 (1 ≤ i ≤ n)

import java.util.Scanner;

public class S2 {
        
    public static void main(String[] args) {
        Scanner in=new Scanner(System.in);
        int n=in.nextInt();
        int [] s=new int[10];
        for (int i = 1; i <= n; i++) {
            s[i]=s[i-1]+in.nextInt();
        }
        int ans=0;
        int mini=0;
        for (int i = 1; i <n; i++) {
            ans=Math.max(ans, s[i]-mini);
            mini=Math.min(s[i], mini);
        }
        System.out.println(ans);
    }
}

 

posted @ 2018-11-29 15:55  ---dgw博客  阅读(596)  评论(0编辑  收藏  举报