zoukankan      html  css  js  c++  java
  • 前缀和应用

     最大和

    ★   输入文件: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);
        }
    }
  • 相关阅读:
    【JOB】Oracle中JOB的创建方法以及一个细节的探究
    PHP安装加载yaf扩展
    微信开发(1) -- 将本地开发环境映射到公网访问
    修改Nginx与Apache上传文件大小限制
    liunx系统安装composer与配置
    Mysql 5.7 liunx 忘记密码的补救方法
    Vim使用技巧(4) -- 命令行模式 【持续更新】
    Vim使用技巧(3) -- 可视化模式技巧 【持续更新】
    Vim使用技巧(2) -- 插入模式技巧 【持续更新】
    Postman 安装及使用入门教程
  • 原文地址:https://www.cnblogs.com/dgwblog/p/10038854.html
Copyright © 2011-2022 走看看