Norma

Time Limit: 20 Sec  Memory Limit: 64 MB
[Submit][Status][Discuss]

Description

  

Input

  第1行,一个整数N;

  第2~n+1行,每行一个整数表示序列a。

Output

  输出答案对10^9取模后的结果。

Sample Input

  4
  2
  4
  1
  4

Sample Output

  109

HINT

  N <= 500000
  1 <= a_i <= 10^8

Solution

 \begin {align}
&基本思路,考虑分治,统计对于左端点在[L,mid],右端点在[mid+1,R]的区间贡献:\\
\\
&枚举在[L, mid]中的点i,[mid+1,R]中的点a、b,\\
&保证min[i,mid]≤min[mid+1,a]\\
&并且max[i,mid]≥max[mid+1,b] \\
&然后[mid+1,R]就被分成了三部分:[mid+1,a],[a+1,b],[b+1,R],(假设a<b),\\
\\
&我们考虑分别对三个部分计算贡献:(max=max[i,mid], min=min[i,mid])\\
&①.[mid+1,a]:Ans=max*min*\sum_{j=mid+1}^{a}(j-i+1) \\
&②.[a+1,b]:Ans=max*\sum_{j=a+1}^{b}(min[a+1,j]*(j-i+1)) \\
&③.[b+1,R]:Ans=\sum_{j=b+1}^{R}( max[b+1,j]*min[b+1,j]*(j-i+1)) \\
\\
&这时候,显然①可求了。我们继续推导(把(j-i+1)拆开),显然有:\\
&②=max*\sum_{j=a+1}^{b}min[a+1,j]*j-max*\sum_{j=a+1}^{b}min[a+1,j]*(i-1)\\
&③=\sum_{j=b+1}^{R}max[b+1,j]*min[b+1,j]*j-\sum_{j=b+1}^{R}max[b+1,j]*min[b+1,j]*(i-1)\\
\\
&显然此时②中的\sum_{j=a+1}^{b}min[a+1,j]*j、\sum_{j=a+1}^{b}min[a+1,j]是可以O(len)预处理的,\\
&③中的\sum_{j=b+1}^{R}max[b+1,j]*min[b+1,j]*j、\sum_{j=b+1}^{R}max[b+1,j]*min[b+1,j]也可以O(len)预处理。\\
\\
&显然,若b<a类似。所以我们分治一下即可。\\
\\
&\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:\:——BearChild \end {align}

BZOJ3745.md

  

Code

 #include<iostream>
#include<string>
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cmath>
using namespace std;
typedef long long s64; const int ONE = ;
const int MOD = 1e9;
const int INF = ; int get()
{
int res = , Q = ; char c;
while( (c = getchar()) < || c > )
if(c == '-') Q = -;
if(Q) res = c - ;
while( (c = getchar()) >= && c <= )
res = res * + c - ;
return res * Q;
} int n;
int val[ONE];
int Ans; void Modit(int &a)
{
if(a < ) a += MOD;
if(a >= MOD) a -= MOD;
} struct power
{
int Min, MinI;
int Max, MaxI;
int MinMax, MinMaxI; friend power operator -(power a, power b)
{
power c;
Modit(c.Min = a.Min - b.Min),
Modit(c.MinI = a.MinI - b.MinI),
Modit(c.Max = a.Max - b.Max),
Modit(c.MaxI = a.MaxI - b.MaxI),
Modit(c.MinMax = a.MinMax - b.MinMax),
Modit(c.MinMaxI = a.MinMaxI - b.MinMaxI);
return c;
}
}A[ONE]; int Sum(int a, int b)
{
return (s64)(a + b) * (b - a + ) / % MOD;
} void Solve(int L, int R)
{
if(L == R)
{
Modit(Ans += (s64)val[L] * val[R] % MOD * );
return;
} int mid = L + R >> ; int minn = INF, maxx = -INF;
A[mid] = (power){, , , , , }; for(int j = mid + ; j <= R; j++)
{
minn = min(minn, val[j]), maxx = max(maxx, val[j]),
Modit(A[j].Min = A[j - ].Min + minn),
Modit(A[j].MinI = A[j - ].MinI + (s64)minn * j % MOD),
Modit(A[j].Max = A[j - ].Max + maxx),
Modit(A[j].MaxI = A[j - ].MaxI + (s64)maxx * j % MOD),
Modit(A[j].MinMax = A[j - ].MinMax + (s64)minn * maxx % MOD),
Modit(A[j].MinMaxI = A[j - ].MinMaxI + (s64)minn * maxx % MOD * j % MOD);
} minn = INF, maxx = -INF;
int a = mid, b = mid;
power del; for(int i = mid; i >= L; i--)
{
minn = min(minn, val[i]), maxx = max(maxx, val[i]);
while(minn <= val[a + ] && a + <= R) a++;
while(maxx >= val[b + ] && b + <= R) b++;
if(a <= b)
{
Modit(Ans += (s64)maxx * minn % MOD * Sum(mid + - i + , a - i + ) % MOD);
del = A[b] - A[a];
Modit(Ans += (s64)maxx * del.MinI % MOD - (s64)maxx * del.Min % MOD * (i - ) % MOD);
del = A[R] - A[b];
Modit(Ans += (s64)del.MinMaxI - (s64)del.MinMax * (i - ) % MOD);
}
else
{
Modit(Ans += (s64)maxx * minn % MOD * Sum(mid + - i + , b - i + ) % MOD);
del = A[a] - A[b];
Modit(Ans += (s64)minn * del.MaxI % MOD - (s64)minn * del.Max % MOD * (i - ) % MOD);
del = A[R] - A[a];
Modit(Ans += (s64)del.MinMaxI - (s64)del.MinMax * (i - ) % MOD);
}
} Solve(L, mid), Solve(mid + , R); } int main()
{
n = get();
for(int i = ; i <= n; i++)
val[i] = get();
Solve(, n);
printf("%d", Ans);
}

  

【BZOJ3745】Norma [分治]的更多相关文章

  1. [BZOJ3745][COCI2015]Norma[分治]

    题意 题目链接 分析 考虑分治,记当前分治区间为 \(l,r\) . 枚举左端点,然后发现右端点无非三种情况: 极大极小值都在左边; 有一个在左边; 极大极小值都在右边; 考虑递推 \(l\) 的同时 ...

  2. bzoj3745: [Coci2015]Norma 分治,单调队列

    链接 bzoj 思路 首先\(\sum\limits_{i=1}^{n}\sum\limits_{j=1}^{n}\sum\limits_{k=i}^{j}max(a_k)\)可以用单调队列求解.参见 ...

  3. BZOJ3745 / SP22343 NORMA2 - Norma 分治,CDQ分治

    要命的题目. 写法:分类讨论进行计算. 枚举过每一个\(mid\)的所有区间.对于左端点\(i∈[l, mid - 1]\),向左推并计算\([l,mid]\)范围内的最大\(/\)最小值. 然后右端 ...

  4. 『Norma 分治』

    Norma Description Input Format 第1行,一个整数N: 第2~n+1行,每行一个整数表示序列a. Output Format 输出答案对10^9取模后的结果. Sample ...

  5. 【CF526F】Pudding Monsters cdq分治

    [CF526F]Pudding Monsters 题意:给你一个排列$p_i$,问你有对少个区间的值域段是连续的. $n\le 3\times 10^5$ 题解:bzoj3745 Norma 的弱化版 ...

  6. PKUSC2018训练日程(4.18~5.30)

    (总计:共66题) 4.18~4.25:19题 4.26~5.2:17题 5.3~5.9: 6题 5.10~5.16: 6题 5.17~5.23: 9题 5.24~5.30: 9题 4.18 [BZO ...

  7. 【BZOJ3745】Norma(CDQ分治)

    [BZOJ3745]Norma(CDQ分治) 题面 BZOJ 洛谷 题解 这种问题直接做不好做,显然需要一定的优化.考虑\(CDQ\)分治. 现在唯一需要考虑的就是跨越当前中间节点的所有区间如何计算答 ...

  8. 【BZOJ3745】[Coci2015]Norma cdq分治

    [BZOJ3745][Coci2015]Norma Description Input 第1行,一个整数N: 第2~n+1行,每行一个整数表示序列a. Output 输出答案对10^9取模后的结果. ...

  9. BZOJ3745 COCI2015Norma(分治)

    完全想不到地,考虑分治. 对区间[l,r],将左端点x由mid不断左移,右边记录最右的p满足max[mid+1,p]<=max[x,mid],q满足min[mid+1,q]>=min[x, ...

随机推荐

  1. "firstday"-软件工程

    阅读以下文章 http://www.thea.cn/news/terminal/9/9389.html    http://www.shzhidao.cn/system/2015/09/22/0102 ...

  2. 小程序解密 encryptedData 获取 unionID 等信息

    index.php <?php include_once "wxBizDataCrypt.php"; // $appid 由小程序微信官方后台获取 $appid = 'wx4 ...

  3. java内存加载机制

    什么是java类加载? 类加载是指将.class类中的二进制数据存放到内存中,会在内存中的推中建立一个java.lang.String的引用对象来存放方法区的数据结构,而类中的数据会放到方法区中 类加 ...

  4. 对Spark2.2.0文档的学习1-Cluster Mode Overview

    Cluster Mode Overview Link:http://spark.apache.org/docs/2.2.0/cluster-overview.html Spark应用(Applicat ...

  5. C++解析(26):函数模板与类模板

    0.目录 1.函数模板 1.1 函数模板与泛型编程 1.2 多参数函数模板 1.3 函数重载遇上函数模板 2.类模板 2.1 类模板 2.2 多参数类模板与特化 2.3 特化的深度分析 3.小结 1. ...

  6. P1053 篝火晚会

    题目描述 佳佳刚进高中,在军训的时候,由于佳佳吃苦耐劳,很快得到了教官的赏识,成为了“小教官”.在军训结束的那天晚上,佳佳被命令组织同学们进行篝火晚会.一共有nnn个同学,编号从111到nnn.一开始 ...

  7. debug - vue中通过ajax获取数据时,如何避免绑定的数据中出现property of undefined错误

    因为获取服务器是异步的,所以 vue 先绑定数据. 如果 ??? 是通过 ajax 异步获取的,在获取之前,???是未定义的.此时在外面的标签上添加一个 v-if="???" 可以 ...

  8. 考研路茫茫――单词情结 HDU - 2243(ac自动机 + 矩阵快速幂)

    考研路茫茫——单词情结 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  9. Ubuntu上搭建比特币运行环境

    Ubuntu版本:16.04.3 Bitcoin Core版本:0.16 1. 比特币运行依赖的开源库 (1)必须依赖的库 库 目的 描述 libssl 加密 随机数生成,椭圆曲线加密算法 libbo ...

  10. 洛谷 P2233 [HNOI2002]公交车路线 解题报告

    P2233 [HNOI2002]公交车路线 题目背景 在长沙城新建的环城公路上一共有8个公交站,分别为A.B.C.D.E.F.G.H.公共汽车只能够在相邻的两个公交站之间运行,因此你从某一个公交站到另 ...