给定 \(m\) 个询问,每个询问是一个区间 \([l,r]\),你需要通过自由地设定每个节点的 \(mid\),设计一种“自适应线段树”,使得在这个线段树上跑这 \(m\) 个区间询问时,需要访问节点的次数最少。

Solution

对于询问 \([ql,qr]\) 和结点 \([l,r]\)

  • 如果 \([ql,qr]\) 与 \([l,r]\) 相交但不包含,贡献为 \(1\)
  • 如果 \([ql,qr]\) 包含 \([l,r]\)
    • 如果 \(l=r\),则贡献 \(1\)
    • 如果 \(l\neq r\),则贡献 \(-1\) (将两个合并为一个,省了一次)

这样一来,我们需要考虑的内容就与树的结构无关,每个结点对应的贡献只和它自身的范围有关

我们可以预处理 \(w[i][j]\) 表示 \([i,j]\) 这个结点产生的贡献,这个贡献可以用前缀和预处理出来

  • 具体地,在 \(i\neq j\) 时,\([i,j]\) 对于任意 \([1\dots j,i \dots n]-[i\dots t,t\dots j]\)都产生了 \(1\) 的贡献,对任意 \([i\dots t,t\dots j]\) 都产生了 \(-1\) 的贡献
  • 而在 \(i=j\) 时,产生 \(1\) 的贡献

设 \(f[i][j]\) 表示处理掉 \([i,j]\) 这段区间的最小答案,那么

\[f[i][j]=\min_k (f[i][k]+f[k+1][j]) + w[i][j]
\]

#include <bits/stdc++.h>
using namespace std;
#define int long long
const int N = 1005; int n,m,t1,t2,w[N][N],f[N][N],x[N]; void modify(int i,int j,int k,int l,int v) {
w[i][k]+=v;
w[i][l+1]-=v;
w[j+1][k]-=v;
w[j+1][l+1]+=v;
} signed main() {
ios::sync_with_stdio(false);
cin>>n>>m;
for(int i=1;i<=m;i++) {
cin>>t1>>t2;
modify(1,t2,t1,n,1);
modify(t1,t2,t1,t2,-2);
x[t1]+=2; x[t2+1]-=2;
}
for(int i=1;i<=n;i++) x[i]+=x[i-1];
for(int i=1;i<=n;i++) {
for(int j=1;j<=n;j++) {
w[i][j]+=w[i-1][j]+w[i][j-1]-w[i-1][j-1];
}
}
for(int i=1;i<=n;i++) w[i][i]+=x[i], f[i][i]=w[i][i];
for(int l=2;l<=n;l++) {
for(int i=1;i+l-1<=n;i++) {
int j=i+l-1;
f[i][j]=1e14;
for(int k=i;k<j;k++) {
f[i][j]=min(f[i][k]+f[k+1][j],f[i][j]);
}
f[i][j]+=w[i][j];
}
}
cout<<f[1][n];
}

Wannafly Winter Camp 2020 Day 5C Self-Adjusting Segment Tree - 区间dp,线段树的更多相关文章

  1. Wannafly Winter Camp 2020 Day 5I Practice for KD Tree - 二维线段树

    给定一个 \(n \times n\) 矩阵,先进行 \(m_1 \leq 5e4\) 次区间加,再进行 \(m_2 \leq 5e5\) 次询问,每次询问要求输出矩形区间内的最大数.\(n \leq ...

  2. Wannafly Winter Camp 2020 Day 7E 上升下降子序列 - 数学

    神奇公式 #include <bits/stdc++.h> using namespace std; #define int long long int n,mod,c[205][205] ...

  3. Wannafly Winter Camp 2020 Day 7D 方阵的行列式 - 数学

    于是去弄了个板子来 #include <bits/stdc++.h> using namespace std; #define int long long const int mod = ...

  4. Wannafly Winter Camp 2020 Day 7A 序列 - 树状数组

    给定一个全排列,对于它的每一个子序列 \(s[1..p]\),对于每一个 \(i \in [1,p-1]\),给 \(s[i],s[i+1]\) 间的每一个值对应的桶 \(+1\),求最终每个桶的值. ...

  5. Wannafly Winter Camp 2020 Day 6J K重排列 - dp

    求 \(K\) 是多少个 \(n\) 元置换的周期.\(T\leq 100, n\leq 50, K \leq 10^{18}\) Solution 置换可以被试做若干个环组成的有向图,于是考虑 dp ...

  6. Wannafly Winter Camp 2020 Day 6I 变大! - dp

    给定一个序列,可以执行 \(k\) 次操作,每次选择连续的三个位置,将他们都变成他们的最大值,最大化 \(\sum a_i\) 需要对每一个 \(k=i\) 输出答案 \(n \leq 50, a_i ...

  7. Wannafly Winter Camp 2020 Day 6H 异或询问 - 二分

    给定一个长 \(n\) 的序列 \(a_1,\dots,a_n\),定义 \(f(x)\) 为有多少个 \(a_i \leq x\) 有 \(q\) 次询问,每次给定 \(l,r,x\),求 \(\s ...

  8. Wannafly Winter Camp 2020 Day 6G 单调栈 - 贪心

    对于排列 \(p\),它的单调栈 \(f\) 定义为,\(f_i\) 是以 \(p_i\) 结尾的最长上升子序列的长度 先给定 \(f\) 中一些位置的值,求字典序最小的 \(p\) 使得它满足这些值 ...

  9. Wannafly Winter Camp 2020 Day 6D 递增递增 - dp,组合数学

    给定两个常为 \(n\) 的序列 \(l_i,r_i\),问夹在它们之间 ( \(\forall i, l_i \leq a_i \leq r_i\) ) 的不降序列的元素总和. Solution 先 ...

随机推荐

  1. DotNetty发送请求的最佳实践

    长链接发送request/response时, 绝大部分包都是小包, 而每个小包都要消耗一个IP包, 成本大约是20-30us, 普通千兆网卡的pps大约是60Wpps, 所以想要提高长链接密集IO的 ...

  2. 如何优雅地使用containerd?这里有一份必读的技巧攻略

    前 言 Docker是我们常用的容器runtime,友好的CLI,丰富的社区资料,外加研发运维人员多年的经验积累,使用Docker几乎是没有任何门槛的事.而k3s为了降低资源消耗,将默认的runtim ...

  3. 非常NB的一款快捷启动软件--Merry

    Merry 被设计为了能将日常重复性操作简化为一个快捷键或者命令.Merry 采用完全开放的体系, 可以使用 Lua 或者外部程序来扩展 Merry 的功能. 另附一个自己扩展的LUA脚本: --启动 ...

  4. 【WPF学习】第四十一章 变换

    通过使用变换(transform),许多绘图任务将更趋简单:变换是通过不加通告地切换形状或元素使用的坐标系统来改变形状或元素绘制方式的对象.在WPF中,变换由继承自System.Windows.Med ...

  5. CCF_ 201509-2_日期计算

    水. #include<iostream> #include<cstdio> using namespace std; ] = {{,,,,,,,,,,,,},{,,,,,,, ...

  6. Codeforces 1197E Count The Rectangles(树状数组+扫描线)

    题意: 给你n条平行于坐标轴的线,问你能组成多少个矩形,坐标绝对值均小于5000 保证线之间不会重合或者退化 思路: 从下到上扫描每一条纵坐标为y的水平的线,然后扫描所有竖直的线并标记与它相交的线,保 ...

  7. How to collect TLOG usage status automatically ?

    Yes , in SQLSERVER, we use "DBCC sqlperf(logspace)" to check transaction logfile status.Bu ...

  8. Nice to meet you for the first time .Why do I write blog!

    他们说我不修边幅,因为他们没看到我对细节的追求,他们说我技术宅,因为他们看不懂我的悲欢,他们说我无趣,是因为她们不知道,我在让世界变得更有趣,我把误解拿来自黑,我用工作承载兴趣,我是程序员,是用代码编 ...

  9. 02-Redis

    今日内容 1. redis 1. 概念 2. 下载安装 3. 命令操作 1. 数据结构 4. 持久化操作 5. 使用Java客户端操作redis Redis 1. 概念:redis是一款高性能的NOS ...

  10. Java Stack使用

    1.Stack继承自Vector.遵从先进后出的规则. 2.Stack 是线程同步的.(map.List.Set是线程不同步的,需要在外部封装的时候来同步) 试例代码: public static v ...