看了题解。

题目大意

你有一个长度为 \(N\) 的全为 $0$ 的序列 \(A\),给你一个长度同样为 \(N\) 的 $0/1$ 序列 \(B\),允许你对把 \(A\) 的一些区间中的数组全部改成 $1$,最小化 \(A\) 和 \(B\) 数字不同的位置个数。

解法

https://img.atcoder.jp/arc085/editorial.pdf

题解写得很清楚了。。。

总之就是把要求的东西进行一些奇妙变换,免去了变为 $1$ 的代价计算,把添加线段的那个没法优化的转移给换掉。。。

UPD:那个转换没有必要,直接 DP 即可。。。

实现

#include <bits/stdc++.h>

using namespace std;

const int INF = 2e9;

struct Node {
typedef Node* NP;
NP l, r;
int sz, mi;
Node(int _sz) : l(NULL), r(NULL), sz(_sz) {
mi = INF;
if (sz == 1) return;
l = new Node(sz/2);
r = new Node(sz-sz/2);
}
void set(int k, int v) {
if (sz == 1) {
mi = min(mi, v);
return;
}
if (k < sz/2) {
l->set(k, v);
} else {
r->set(k-sz/2, v);
}
mi = min(l->mi, r->mi);
}
int get(int a, int b) {
if (b <= 0 || sz <= a) return INF;
if (a <= 0 && sz <= b) return mi;
return min(l->get(a, b), r->get(a-sz/2, b-sz/2));
}
}; const int MN = 200010;
int n, q;
int b[MN];
vector<int> v[MN]; int main() {
cin.tie(0);
ios::sync_with_stdio(false); cin >> n;
int ans = 0;
for (int i = 0; i < n; i++) {
cin >> b[i];
if (b[i] == 0) {
ans++;
b[i]--;
}
}
cin >> q;
for (int i = 0; i < q; i++) {
int l, r;
cin >> l >> r; l--;
v[l].push_back(r);
}
Node* tr = new Node(n+1);
for (int i = 0; i <= n; i++) {
if (i) {
tr->set(i, tr->get(i-1, i) + b[i-1]);
} else {
tr->set(0, 0);
}
for (int j = 0; j < int(v[i].size()); j++) {
int r = v[i][j];
tr->set(r, tr->get(i, r));
}
}
ans += tr->get(n, n+1);
cout << ans << endl;
return 0;
}

ARC085F NRE的更多相关文章

  1. NRE

    NRE是Non-Recurring Engineering的缩写,NRE费用即一次性工程费用,是指集成电路生产成本中非经常性发生的开支,明确地说就是新的集成电路产品的研制开发费·新产品开发过程中的设计 ...

  2. ARC085F(动态规划,线段树)

    #include<bits/stdc++.h>using namespace std;const int maxn = 0x3f3f3f3f;int mn[801000];int cost ...

  3. [atARC085F]NRE

    令$(S_{a},S_{b})$表示$a_{i}\in S_{a}$且$b_{i}\in S_{b}$的i个数,那么答案相当于$S(0,1)+S(1,0)=S(0,1)+S(\{0,1\},0)-S( ...

  4. [ActiveMQ]初识ActiveMQ

    初识ActiveMQ ActiveMQ介绍 官方网站:http://activemq.apache.org/ 最新版本:ActiveMQ 5.14.1(2016-10-28) 最新版本下载链接:htt ...

  5. 谈谈SQL 语句的优化技术

    https://blogs.msdn.microsoft.com/apgcdsd/2011/01/10/sql-1/ 一.引言 一个凸现在很多开发者或数据库管理员面前的问题是数据库系统的性能问题.性能 ...

  6. Android学习——windows下搭建NDK_r9环境

    1. NDK(Native Development Kit) 1.1 NDK简介 Android NDK是一套允许开发人员使用本地代码(如C/C++)进行Android APP功能开发的工具,通过这个 ...

  7. java web学习总结(六) -------------------servlet开发(二)

    一.ServletConfig讲解 1.1.配置Servlet初始化参数 在Servlet的配置文件web.xml中,可以使用一个或多个<init-param>标签为servlet配置一些 ...

  8. 深入理解C++对象模型

    C++对象模型是比较重要的一个知识点,学习C++对象的内存模型,就可以明白C++中的多态原理.类的初始化顺序问题.类的大小问题等. 1 C++对象模型基础 1.1 C++对象中都有哪些东东 C++对象 ...

  9. servlet(二)

    一.ServletConfig讲解 1.1.配置Servlet初始化参数 在Servlet的配置文件web.xml中,可以使用一个或多个<init-param>标签为servlet配置一些 ...

随机推荐

  1. KMP算法详细分解

    1. 引言 给定一个主串(以 S 代替)和模式串(以 P 代替),要求找出 P 在 S 中出现的位置,此即串的模式匹配问题. Knuth-Morris-Pratt 算法(简称 KMP)是解决这一问题的 ...

  2. WEB学习笔记10-高可读性的HTML之HTML 语义化

    实现如下所示工具栏: 做到标签语义化,首先要尽量减少使用<div>和<span>这两个标签. 分析:这是一个包含5个无序操作项的工具栏,因此应该使用符合语义的<ul> ...

  3. python程序在命令行执行提示ModuleNotFoundError: No module named 'XXX' 解决方法

    在ide中执行python程序,都已经在默认的项目路径中,所以直接执行是没有问题的.但是在cmd中执行程序,所在路径是python的搜索路径,如果涉及到import引用就会报类似ImportError ...

  4. Failed to load ApplicationContext ,Error creating bean with name 'adminUserService': Injection of autowired dependencies failed;

    Druid配置的时候出现这个问题: "C:\Program Files\Java\jdk1.8.0_191\bin\java" -ea -Didea.test.cyclic.buf ...

  5. python笔记-数学、元组、日期、文件

    python在很多地方和C++相似,比如都会有关系.逻辑等运算符,但也有不同的地方,比如:#Python Number 类型转换int(x [,base ]) 将x转换为一个整数 long(x [,b ...

  6. webpack 学习之旅

    首先理解wepack的打包原理:一般单页面应用,你的页面都会引入一个类似bundle.js的文件,在react项目中,你会发现index.html中并没有引入css,那么css哪里去了?答案是它被打包 ...

  7. ssh 端口更改或ssh 远程接不上的问题(尤其是国外服务器)

    问题: Connecting to 149.*.*.*:22...Connection established.To escape to local shell, press 'Ctrl+Alt+]' ...

  8. 常用socket选项

    1.socket选项通常:服务端应在listen 前设置,accpet返回的socket继承自监听套接字. 客户端应在connect之前设置 2.socket 如果有大量短连接应设置SO_LINGER ...

  9. JVM运行时数据区域

    上面已经聊过JVM是什么东东,也谈过了JVM内存的垃圾回收机制.这一篇博客我们来聊聊JVM运行时数据区域. JVM运行时数据区域由5块部分组成,分别是堆,方法区,栈,本地方法栈,以及程序计数器组成. ...

  10. tornado--启动

    tornado--启动 from tornado import web from tornado import ioloop from tornado.httpserver import HTTPSe ...