• 前缀和应用


     最大和

    ★   输入文件: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);
        }
    }
  • 相关阅读:
    asp.net实现页面的一般处理程序(CGI)学习笔记
    .NET下的状态(State)模式 行为型模式
    (插件Plugin)AssemblyLoader解决方案(插件开发)
    SQL基础编写基本的SQL SELECT 语句
    在查询语句中使用NOLOCK和READPAST(ZT)
    C# 3.0语言增强学习笔记(一)
    ram,rom,flash
    自动激活你的ActiveX控件
    用C#编写ActiveX控件(二)
    用C#编写ActiveX控件(一)
  • 原文地址:https://www.cnblogs.com/dgwblog/p/10038854.html
Copyright © 2020-2023  润新知