hdu4719 Oh My Holy FFF 线段树优化dp
思路
好久之前的了,忘记什么题目了
可以到我这里做luogu
反正就是hdu数据太水,导致自己造的数据都过不去,而hdu却A了
好像是维护了最大值和次大值,然后出错的几率就小了很多也许是自己写错了,忘记了
留坑待补
代码
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#define ll long long
#define ls rt<<1
#define rs rt<<1|1
using namespace std;
const int maxn = 1e5 + 7;
int n, l, T, cnt,a[maxn];
ll f[maxn];
int read()
{
int x=0,f=1;char s=getchar();
for(;s>'9'||s<'0';s=getchar()) if(s=='-') f=-1;
for(;s>='0'&&s<='9';s=getchar()) x=x*10+s-'0';
return x*f;
}
struct node {
int l, r;
ll ma,flag;
} e[maxn << 2];
void pushup(int rt) {
e[rt].ma = max(e[ls].ma, e[rs].ma);
}
void build(int l, int r, int rt) {
e[rt].l = l, e[rt].r = r;
if (l == r) {
e[rt].ma = -1LL;
e[rt].flag=0;
return;
}
int mid = (l + r) >> 1;
build(l, mid, ls);
build(mid + 1, r, rs);
pushup(rt);
}
void modfity(int L, ll k, int rt) {
if (e[rt].l == e[rt].r) {
if (e[rt].ma == k) e[rt].flag++;
else if (e[rt].ma < k) {
e[rt].ma = k;
e[rt].flag = 0ll;
}
return;
}
int mid = (e[rt].l + e[rt].r) >> 1;
if (L <= mid) modfity(L, k, ls);
else modfity(L, k, rs);
pushup(rt);
}
void delet(int L, ll k, int rt) {
if (e[rt].l == e[rt].r) {
if (k == e[rt].ma) {
if (e[rt].flag >= 1) e[rt].flag--;
else e[rt].ma = -1;
}
return;
}
int mid = (e[rt].l + e[rt].r) >> 1;
if (L <= mid) delet(L, k, ls);
else delet(L, k, rs);
pushup(rt);
}
ll query(int L, int R, int rt) {
if (L <= e[rt].l && e[rt].r <= R) {
return e[rt].ma;
}
int mid = (e[rt].l + e[rt].r) >> 1;
ll ans = -1LL;
if (L <= mid) ans = max(ans, query(L, R, ls));
if (R > mid) ans = max(ans, query(L, R, rs));
return ans;
}
int main() {
T=read();
for (; T--;) {
n=read(),l=read();
memset(f, -1, sizeof(f));
for (int i = 1; i <= n; ++i) {
a[i]=read();
}
build(1, 1e5, 1);
for (int i = 1; i <= n; ++i) {
if ((i - l) > 1) {
delet(a[i - l - 1] + 1, f[i - l - 1] - a[i - l - 1], 1);
}
if (a[i] == 1) {
if (i > l) {
f[i] = -1LL;
continue;
} else f[i] = (ll)a[i] * a[i];
} else {
ll tmp = query(1, a[i], 1);
if (tmp == -1LL) {
if (i > l) {
f[i] = -1LL;
continue;
} else
f[i] = a[i] * a[i];
} else {
f[i] = (ll)a[i] * a[i] + tmp;
}
}
modfity(a[i] + 1, f[i] - a[i], 1);
}
if (f[n] == -1) printf("Case #%d: No solution\n", ++cnt);
else printf("Case #%d: %lld\n", ++cnt, f[n]);
}
return 0;
}
/*
区间大小一定
求给点区间大小的小于a[i]的max
按照a[i]的权值建一颗线段树求max
区间类似于queue,删点 即可
可是删点会有几率GG掉,记录size也会GG掉
*/
hdu4719 Oh My Holy FFF 线段树优化dp的更多相关文章
- hdu4719 Oh My Holy FFF 线段树维护dp
题意:给你一个长度为n的数组v,你需要把这个数组分成很多段,你需要保证每一段的长度不能超过k我们设一共有m段,每一段右边界那个数为bi那么我们要使得sum(bi*bi-b(i-1))最大 (1< ...
- Codeforces Round #426 (Div. 2) D 线段树优化dp
D. The Bakery time limit per test 2.5 seconds memory limit per test 256 megabytes input standard inp ...
- BZOJ2090: [Poi2010]Monotonicity 2【线段树优化DP】
BZOJ2090: [Poi2010]Monotonicity 2[线段树优化DP] Description 给出N个正整数a[1..N],再给出K个关系符号(>.<或=)s[1..k]. ...
- [AGC011F] Train Service Planning [线段树优化dp+思维]
思路 模意义 这题真tm有意思 我上下楼梯了半天做出来的qwq 首先,考虑到每K分钟有一辆车,那么可以把所有的操作都放到模$K$意义下进行 这时,我们只需要考虑两边的两辆车就好了. 定义一些称呼: 上 ...
- 【bzoj3939】[Usaco2015 Feb]Cow Hopscotch 动态开点线段树优化dp
题目描述 Just like humans enjoy playing the game of Hopscotch, Farmer John's cows have invented a varian ...
- POJ 2376 Cleaning Shifts (线段树优化DP)
题目大意:给你很多条线段,开头结尾是$[l,r]$,让你覆盖整个区间$[1,T]$,求最少的线段数 题目传送门 线段树优化$DP$裸题.. 先去掉所有能被其他线段包含的线段,这种线段一定不在最优解里 ...
- 洛谷$P2605\ [ZJOI2010]$基站选址 线段树优化$dp$
正解:线段树优化$dp$ 解题报告: 传送门$QwQ$ 难受阿,,,本来想做考试题的,我还造了个精妙无比的题面,然后今天讲$dp$的时候被讲到了$kk$ 先考虑暴力$dp$?就设$f_{i,j}$表示 ...
- D - The Bakery CodeForces - 834D 线段树优化dp···
D - The Bakery CodeForces - 834D 这个题目好难啊,我理解了好久,都没有怎么理解好, 这种线段树优化dp,感觉还是很难的. 直接说思路吧,说不清楚就看代码吧. 这个题目转 ...
- 4.11 省选模拟赛 序列 二分 线段树优化dp set优化dp 缩点
容易想到二分. 看到第一个条件容易想到缩点. 第二个条件自然是分段 然后让总和最小 容易想到dp. 缩点为先:我是采用了取了一个前缀最小值数组 二分+并查集缩点 当然也是可以直接采用 其他的奇奇怪怪的 ...
随机推荐
- Flip Game---poj1753(状压+bfs)
题目链接:http://poj.org/problem?id=1753 题意:是有一个4X4的图,b代表黑色,w代表白色,问最少翻转几次可以把所有的点变成白色或者黑色,每次翻转一个点时,可以把它 ...
- 理解CopyOnWriteArrayList
CopyOnWriteArrayList,顾名思义,Write的时候总是要Copy,也就是说对于任何可变的操作(add.set.remove)都是伴随复制这个动作的 A thread-safe var ...
- qt——c++环境下qt编程,类的声明与构造
在c++中创建项目时,会生成以项目名字命名的QMainWindow,以及相应的头文件和CPP文件,作为主要窗口: 在项目中继续生成qt类时,比如类的名称是test,会自动生成一个test.h的头文件, ...
- Shell 和Python的区别。
shell 应该属于宏语言,顾名思义是系统的壳,方便与系统交互的在以下情况下,不使用shell,因为shell对此无能为力:如:跨平台,较复杂数学操作(如浮点运算,精确运算等),图形化界面 GUI,I ...
- Jquery WeUI(一)
用于微信端的控件UI , 首先,需要做的是开发一个微信能访问的网页,并和微信关联 A. 创建一个空网站 B. 增加一般处理程序 A. 增加 web 网页 和空文件到项目中 B. 申请和配置测试服务 创 ...
- [LeetCode] 104. Maximum Depth of Binary Tree_Easy tag: DFS
Given a binary tree, find its maximum depth. The maximum depth is the number of nodes along the long ...
- [LeetCode] 675. Cut Off Trees for Golf Event_Hard tag: BFS
You are asked to cut off trees in a forest for a golf event. The forest is represented as a non-nega ...
- Amazon SES SPF和DKIM设置教程
SPF和DKIM设置是争对域名邮箱而言的(公共邮件也不会给你修改DNS的权限),主要作用就是防止邮箱伪造提升邮件信用度 首先到亚马逊添加域名并验证 添加后,给出了域名验证的方法,就是在dns记录里添加 ...
- qt mysql驱动问题解绝
传统解决方法:一.解决问题 本文解决在Ubuntu16.04系统下,Qt5无法连接MySQL数据库的问题(Qt5缺少MySQL驱动,Qt5缺少libqsqlmysql.so动态库,如何安装libqsq ...
- minicom的安装和tftp的安装
1.minicom 的安装 在弹出的窗口中选择“Serial port setup”进行配置.配置完之后选择“Save setup as dfl”保存.最后选择“Exit from Minicom”退 ...