参考链接:https://blog.csdn.net/hzk_cpp/article/details/80407014

题目链接:https://www.acwing.com/problem/content/102/

前缀和:

就是一个数组,要快速静态查询区间和,我们只要处理一个数组时A[i]=a[1]+a[2]+...+a[i].

A[1]=a[1]

A[2]=a[1]+a[2]

A[3]=a[1]+a[2]+a[3]

A[4]=a[1]+a[2]+a[3]+a[4]

......

例如:求[2,4]的区间和,A[4]-A[1]=a[2]+a[3]+a[4]=a[1]+a[2]+a[3]+a[4]-(a[1])

那么查询区间[l,r]的时候只要输出A[r]-A[l-1].

那么这是时候预处理是O(n)的,查询一次是O(1).

在很多情况下这种算法都是可行的,但是必须满足区间减法的性质.

代码预处理如下:

for (int i=1;i<=n;i++)
A[i]=A[i-1]+a[i];
差分:

只不过它可以配套前缀和使用.

差分是一种很巧妙的思想,它的主要用途是维护一个区间的快速修改(加减),但查询是单次的时候.O(n+m)

这种思想的主体就是维护一个数组A,其中A[i]=原数组a[i]-a[i-1].

那么就是刚好与前缀和有点像.

也是互逆的运算.

那么这怎么快速维护呢?

也就是说给区间[l,r]+num.

那么就是给开头A[l]+num,再给结尾A[r+1]-num.

很好理解啊.

那么实现如下:

void add(int l,int r,int num){
A[l]+=num;A[r+1]-=num;
}
那么最后需要查询了,就这样处理一下:

for (int i=1;i<=n;i++)
a[i]=a[i-1]+A[i];
那么就是原来的数组了.

时间复杂度O(1)修改,O(n)查询.

差分就是将数列中的每一项分别与前一项数做差,例如:

一个序列1 2 5 4 7 3,差分后得到1 1 3 -1 3 -4 -3

这里注意得到的差分序列第一个数和原来的第一个数一样(相当于第一个数减0)

差分序列最后比原序列多一个数(相当于0减最后一个数)

性质:

1、差分序列求前缀和可得原序列

2、将原序列区间[L,R]中的元素全部+1,可以转化操作为差分序列L处+1,R+1处-1

3、按照性质2得到,每次修改原序列一个区间+1,那么每次差分序列修改处增加的和减少的相同

public class Main {
//前缀和
public static void fun(int arr[],int A[]){
/*
A[1]=a[1] A[2]=a[1]+a[2] A[3]=a[1]+a[2]+a[3] A[4]=a[1]+a[2]+a[3]+a[4]
*/
for (int i=1;i<arr.length;i++)
A[i]=A[i-1]+arr[i]; }
public static int query(int l,int r,int A[]){
//查询区间[l,r]的时候只要输出A[r]-A[l-1]
return A[r]-A[l-1];
}
//差分
public static void fun2(int arr[],int A[]){
for (int i=1;i<arr.length;i++)
A[i]=arr[i]-arr[i-1];
}
public static void add(int l,int r,int num,int A[],int arr[]){
A[l]+=num;A[r+1]-=num;
for (int i=1;i<A.length;i++)
arr[i]=arr[i-1]+A[i];
} public static void main(String[] args) {
int arr[]={0,1,2,3,4};
int A[]=new int[5];
// fun(arr, A);
// System.out.println(query(1, 3, A));
// System.out.println(query(2, 4, A)); fun2(arr, A);
add(1, 3, 9, A, arr);
for (int i = 1; i < arr.length; i++) {
System.out.println(arr[i]);
}
} }

IncDec sequence 题解

对于一个给定的数列arr,它的差分数列A定义为, A[1]=arr[1],A[i]=arr[i]−arr[i−1](2<=i<=n) 即:A[1]=arr[1],A[i]=arr[i]−arr[i−1](2<=i<=n)

性质,把序列arr的区间[L,R]加d,也就是把arr[l],arr[l+1]........arr[r]都加上d,其实就是它的差分序列B中,A[l]+d,A[r+1]−d其他的位置统统不改变。
因此在这道题目中,我们就可以利用这个性质,因为我们只要求arr序列中所有的数相同,而不在意这些方案具体是什么,所以说我们就可以转化题目,也就是将对arr序列的+1,−1+1,−1操作,让arr序列相同,改成目标把A2,…,An变成全0即可(因为A[1]=arr[1],所以是A2~A[n]变成0),也就是arr序列全部相等。而且最后得到的arr序列,就是这n个A1
因为我们有上面所说的性质,那么我们就可以,每一次选取Ai和Aj,2<=i,j<=n而且这两个数,一个为正数,一个为负数,至于为什么要是正负配对,因为我们是要这个A序列2~n都要为0,所以这样负数增加,正数减少,就可以最快地到达目标为0的状态。
至于那些无法配对的数Ak可以选A1,进行修改。即Ak+d,A1-k,A1不影响全局操作
所以说我们这道题目得出的答案就是,最少操作数 min(p,q)+abs(p−q),然后最终序列a可能会有abs(p−q)+1种情况。p为b序列中正数之和,而q为b序列中负数之和

package 差分与前缀和;

import java.util.Scanner;

public class Main1 {
public static void fun2(long arr[],long A[]){
for (int i=1;i<arr.length;i++)
A[i]=arr[i]-arr[i-1];
}
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
int n=sc.nextInt();
long arr[]=new long[n+1];
for (int i = 1; i < arr.length; i++) {
arr[i]=sc.nextLong();
}
long A[]=new long[n+1];
fun2(arr, A);
long positiveNumber=0;
long negativeNumber=0;
for (int i = 2; i < A.length; i++) {
if (A[i]>=0) {
positiveNumber+=A[i];
}else{
negativeNumber-=A[i];
}
}
System.out.println(Math.abs(positiveNumber-negativeNumber)+Math.min(negativeNumber, positiveNumber));
System.out.println(Math.abs(positiveNumber-negativeNumber)+1);
} }

前缀和与差分之IncDec sequence的更多相关文章

  1. 【BZOJ 3043】 3043: IncDec Sequence (差分)

    3043: IncDec Sequence Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 589  Solved: 332 Description 给 ...

  2. bzoj 3043: IncDec Sequence 模拟

    3043: IncDec Sequence Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 248  Solved: 139[Submit][Statu ...

  3. Poetize6: IncDec Sequence

    3043: IncDec Sequence Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 233  Solved: 132[Submit][Statu ...

  4. 【BZOJ3043】IncDec Sequence 乱搞

    [BZOJ3043]IncDec Sequence Description 给定一个长度为n的数列{a1,a2...an},每次可以选择一个区间[l,r],使这个区间内的数都加一或者都减一.问至少需要 ...

  5. BZOJ 3043: IncDec Sequence

    3043: IncDec Sequence Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 578  Solved: 325[Submit][Statu ...

  6. 2498 IncDec Sequence

    2498 IncDec Sequence  时间限制: 1 s  空间限制: 64000 KB  题目等级 : 钻石 Diamond 题解  查看运行结果     题目描述 Description 给 ...

  7. CH-0304 IncDec Sequence

    0304 IncDec Sequence 0x00「基本算法」例题 描述 给定一个长度为 n(n≤10^5 ) 的数列 {a_1,a_2,…,a_n},每次可以选择一个区间 [l,r],使下标在这个区 ...

  8. 差分:IncDec Sequence 差分数组

    突然就提到了这个东西,为了不再出现和去年联赛看见二分没学二分痛拿二等第一的情况,就去学了一下,基础还是比较简单的-- 先看一个经典例题: 给定一个长度为n的数列{a1,a2...an},每次可以选择一 ...

  9. IncDec Sequence(差分)

    题意:给定一个序列,可以对一个区间进行加1或减1的操作,问最少需要多少次可以将序列的值一样. Solution 我们将序列差分,得到一个差分数组. 对于每一个区间操作,我们可以把它转化为在查分数组上某 ...

随机推荐

  1. oracle 常用(二)

    多表查询: 1.等值连接查询: select a.aa,a.bb,b.qq from XX  a ,   CC  b   where a.aa= b.ee 2.不等值连接: select  *  fr ...

  2. php实现记住密码下次自动登陆

    这篇博客里面还写到 实现“记住我的登录状态”的功能方法,简言之,就是对首先对session进行用户信息赋值,检测session,失效后,利用cookie对其赋值: 在实现过程中,根据网上一些代码贴,整 ...

  3. 原型链(_proto_) 与原型(prototype) 有啥关系?

    prototype对象里面方法及属性是共享的...... 1.JavaScript 中每一个对象都拥有原型链(__proto__)指向其构造函数的原型( prototype),object._prot ...

  4. JavaScript原型继承的实例

    // 创建构造函数实例(获取DOM节点) <div id="app">测试字符</div>

  5. 假如java类里的成员变量是自身的对象

    假如java类里的成员变量是自身的对象,则新建该类对象时内存中怎么分配空间,我感觉似乎死循环了. 不过我想的肯定是错的,因为很多类的成员变量是自身对象,并且绝对无错,举个例子: Class A{ pr ...

  6. 检索系统向量化计算query-doc相似度

    def cal_sim2(A,B): ''' A :query [1,2] B: answers [[1,2],[3,5]] ''' need_norm=False A = np.array(A) B ...

  7. 终极解决liunx GUI 无法显示中文的问题。

    为linux安装字体 Linux字体文件放在/usr/share/font/,只要将字体文件拷贝到这里就可以了.这里示例安装Windows的所有字体. 2,复制Windows下 的所有字体.cd命令切 ...

  8. 说说html 的<!DOCTYPE>声明&标准模式与兼容模式

    我们都知道<!DOCTYPE>声明位于文档的最前面,处于<html>标签之前. <!DOCTYPE>声明不是html标签,它的作用:告知web浏览界面应该使用哪个h ...

  9. Abandoned country(最小生成树+树形DP)

    #include<bits/stdc++.h> using namespace std; struct node{ int u, v, w, nex; bool gone; node(){ ...

  10. kalinux 五笔安装

    1.输入命令 sudo apt-get install fcitx-table-wubi 2.配置,找到这个fcitx配置,运行,把五笔调到第2个 3.reboot重启系统