题解:P7482 不条理狂诗曲

本题解借鉴 blossom_j 大佬思路,但这位大佬的题解似乎没放正确代码。

题意

对于每一个 \(a\) 的子区间 \(a_{l\dots r}\),求选择若干个不连续的数的和的最大值,对答案取模 \(10^{9}+7\)。

思路

主要算法:分治。

计算跨过中点 \(mid\) 的区间的 \(f\) 之和。

首先我们可以写一个 DP。\(f_{i,0/1,0/1}\) 表示 DP 已到达 \(i\) 的位置。第一个 \(0/1\) 表示 \(mid\) 或 \(mid+1\) 是否被选择。第二个 \(0/1\) 表示是否选择了第 \(i\) 个元素。

枚举 \(l\) 对所有的 \(r\) 求和:设 \(g_{i,j}=\max\{f_{i,j,0},f_{i,j,1}\}\)。区间 $\left [ l,r \right ] $ 的答案就是 \(\max\{g_{l,0}+\max\{g_{r,0},g_{r,1}\},g_{l,1}+g_{r,0}\}\)。

若 \(g_{l,0}-g_{l,1}\le g_{r,0}-\max\{g_{r,0},g_{r,1}\}\),则必需选择后者。

将 \(g_{r,0}-\max\{g_{r,0},g_{l,1}\}\) 排序,二分寻找分界点。

代码

#include<bits/stdc++.h>
#define int long long
using namespace std;
const int mod = 1000000007, Maxn = 2 * 1e5 + 10;
int n, a[Maxn], ans = 0, f[Maxn][2][2], g[Maxn][2],sa[Maxn], sb[Maxn];
struct Node {
int date, ID;
} d[Maxn]; bool cmp(Node x, Node y) {
return x.date < y.date;
} int ask(int x, int l, int r) {
while (l < r) {
int mid = (l + r + 1) >> 1;
if (d[mid].date <= x)l = mid;
else r = mid - 1;
}
return l;
} void solve(int l, int r) {
if (l == r) {
ans = (ans + a[l]) % mod;
return;
} int mid = (l + r) >> 1;
f[mid + 1][0][0] = f[mid + 1][0][1] = f[mid + 1][1][0] = 0, f[mid + 1][1][1] = a[mid + 1]; g[mid + 1][0] = f[mid + 1][0][0];
g[mid + 1][1] = f[mid + 1][1][1]; d[mid + 1].ID = mid + 1;
d[mid + 1].date = g[mid + 1][0] - max(g[mid + 1][0], g[mid + 1][1]); for (int i = mid + 2; i <= r; i++) {
f[i][0][0] = max(f[i - 1][0][0], f[i - 1][0][1]);
f[i][1][0] = max(f[i - 1][1][0], f[i - 1][1][1]);
f[i][0][1] = f[i - 1][0][0] + a[i];
f[i][1][1] = f[i - 1][1][0] + a[i]; g[i][0] = max(f[i][0][0], f[i][0][1]);
g[i][1] = max(f[i][1][0], f[i][1][1]); d[i].ID = i;
d[i].date = g[i][0] - max(g[i][0], g[i][1]);
} sort(d + mid + 1, d + r + 1, cmp); sa[mid] = sb[mid] = sa[r + 1] = sb[r + 1] = 0;
for (int i = mid + 1; i <= r + 1; i++) {
sa[i] = sa[i - 1] + g[d[i].ID][0];
sb[i] = sb[i - 1] + max(g[d[i].ID][0], g[d[i].ID][1]);
} f[mid][0][0] = f[mid][0][1] = f[mid][1][0] = 0, f[mid][1][1] = a[mid]; g[mid][0] = f[mid][0][0];
g[mid][1] = f[mid][1][1]; int k = ask(g[mid][0] - g[mid][1], mid, r);
ans = (ans + g[mid][0] * (k - mid) % mod + sb[k] + sa[r] - sa[k] + g[mid][1] * (r - k) % mod + mod) % mod; for (int i = mid - 1; i >= l; i--) {
f[i][0][0] = max(f[i + 1][0][0], f[i + 1][0][1]);
f[i][1][0] = max(f[i + 1][1][0], f[i + 1][1][1]);
f[i][0][1] = f[i + 1][0][0] + a[i];
f[i][1][1] = f[i + 1][1][0] + a[i]; g[i][0] = max(f[i][0][0], f[i][0][1]);
g[i][1] = max(f[i][1][0], f[i][1][1]); int k = ask(g[i][0] - g[i][1], mid, r);
ans = (ans + g[i][0] * (k - mid) % mod + sb[k] + sa[r] - sa[k] + g[i][1] * (r - k) % mod + mod) % mod;
} solve(l, mid), solve(mid + 1, r);
}
signed main() {
cin >> n;
for (int i = 1; i <= n; i++)cin >> a[i];
solve(1, n);
cout << ans << '\n';
return 0;
}

题解:P7482 不条理狂诗曲的更多相关文章

  1. BZOJ2821:作诗——题解

    http://www.lydsy.com/JudgeOnline/problem.php?id=2821 问题描述 神犇SJY虐完HEOI之后给傻×LYD出了一题: SHY是T国的公主,平时的一大爱好 ...

  2. 【BZOJ2821】作诗 题解(分块+前缀和)

    前言:世间还有这么卡常的题…… ------------------ 题目链接 题目大意:给定长度为$n$的序列${a_i}$.有$m$次询问,问$[l,r]$内出现正偶数次的数字有多少个. 这题跟蒲 ...

  3. 洛谷 P4135 作诗 题解

    题面. 之前做过一道很类似的题目 洛谷P4168蒲公英 ,然后看到这题很快就想到了解法,做完这题可以对比一下,真的很像. 题目要求区间内出现次数为正偶数的数字的数量. 数据范围1e5,可以分块. 我们 ...

  4. 【BZOJ2821】作诗(Poetize) 分块

    Description 神犇SJY虐完HEOI之后给傻×LYD出了一题:SHY是T国的公主,平时的一大爱好是作诗.由于时间紧迫,SHY作完诗之后还要虐OI,于是SHY找来一篇长度为N的文章,阅读M次, ...

  5. JSOI2015 一轮省选 个人题解与小结

    T1: 题目大意:现有一个以1为根节点的树,要求从1开始出发,经过下面的点然后最终要回到根节点.同时除了根节点之外各点均有一个权值(即受益,每个点上的收益只能拿一次,且经过的话必须拿),同时除了根节点 ...

  6. vijos1010题解

    题目: 话说乾隆带着他的宰相刘罗锅和你出巡江南,被杭州城府邀请去听戏,至于什么戏,那就不知了.乾隆很高兴,撒酒与君臣共享.三更欲回住处,可是乾隆这人挺怪,他首先要到西湖边散散步,而且命令不准有人跟着他 ...

  7. 【分块】BZOJ2821 作诗(Poetize)

    2821: 作诗(Poetize) Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 3265  Solved: 951[Submit][Status][ ...

  8. PAT甲级题解(慢慢刷中)

    博主欢迎转载,但请给出本文链接,我尊重你,你尊重我,谢谢~http://www.cnblogs.com/chenxiwenruo/p/6102219.html特别不喜欢那些随便转载别人的原创文章又不给 ...

  9. CH4907 作诗

    题意 4907 作诗 0x49「数据结构进阶」练习 描述 神犇SJY虐完HEOI之后给傻×LYD出了一题:SHY是T国的公主,平时的一大爱好是作诗.由于时间紧迫,SHY作完诗之后还要虐OI,于是SHY ...

  10. bzoj 1860: [Zjoi2006]Mahjong麻将 题解

    [原题] 1860: [Zjoi2006]Mahjong麻将 Time Limit: 1 Sec  Memory Limit: 64 MB Submit: 211  Solved: 122 [Subm ...

随机推荐

  1. Abp vNext 框架 文章

    http://www.vnfan.com/helinbin/tag/Abp%20vNext框架/

  2. css3 浏览器前缀 线型渐变 过渡属性

    css3:没有形成正式版 每个浏览器商,为了能对css3属性形成一个更好的支持,浏览器形成自己一套语法规范,一些css属性,如果想在浏览器上形成支持,有时候需要添加浏览器前缀 谷歌前缀:-webkit ...

  3. 算法学习笔记(35): CMD Tree

    对于 CMD Tree 的理解 原文:# 一种轻量级平衡树 这,EXSGT,感觉很像支持分裂 WBLT,但是相对来说思路很简单. 首先,在原文中说了: 能以均摊 \(\Theta(\log n)\) ...

  4. kettle从入门到精通 第十三课 kettle 字符串操作

    1.本次示例讲解一些常用的字符串操作,有字段拼接,枚举值转换,计算器.字符串替换.字段拆分. 2.输入元数据有firstName.secondName.sex.salary.englishName.o ...

  5. Vue3:项目创建

    Vue 3 相对于 Vue 2 带来了许多改进和优点,这些改进主要是为了提高性能.开发体验和可维护性.但是对于创建项目,Vue3也可以采用跟Vue2相同的方式. 使用CLI创建 1. 安装Vue CL ...

  6. Puremvc

    Puremvc 框架unitypuremvc PureMVC健壮.易扩展.易维护 Many so-called Model-View-Controller frameworks today seem ...

  7. python 使用pandas修改数据到excel,报“SettingwithCopyWarning A value is trying to be set on a copy of a slice from a DataFrame”的解决方法

    场景: 通过pandas模块,将测试数据回写到excel,测试数据有写到excel文件,但控制台输出警告信息如下 警告: SettingwithCopyWarning A value is tryin ...

  8. 数据标注工具 doccano | 命名实体识别(Named Entity Recognition,简称NER)

    目录 安装 数据准备 创建项目 创建抽取式任务 上传 定义标签 构建抽取式任务标签 任务标注 命名实体识别 导出数据 查看数据 命名实体识别(Named Entity Recognition,简称NE ...

  9. 【干货】Vue3 组件通信方式详解

    前言 毫无疑问,组件通信是Vue中非常重要的技术之一,它的出现能够使我们非常方便的在不同组件之间进行数据的传递,以达到数据交互的效果.所以,学习组件通信技术是非常有必要的,本文将总结Vue中关于组件通 ...

  10. Android 中的 perfboot工具

    背景 开机首先加载bootloader,由bootloader启动kernel,然后运行init程序,有init启动Zygote,Zygote进程启动SystemServ进程,在SystemServe ...