ARC085F NRE
看了题解。
题目大意
你有一个长度为 \(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的更多相关文章
- NRE
NRE是Non-Recurring Engineering的缩写,NRE费用即一次性工程费用,是指集成电路生产成本中非经常性发生的开支,明确地说就是新的集成电路产品的研制开发费·新产品开发过程中的设计 ...
- ARC085F(动态规划,线段树)
#include<bits/stdc++.h>using namespace std;const int maxn = 0x3f3f3f3f;int mn[801000];int cost ...
- [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( ...
- [ActiveMQ]初识ActiveMQ
初识ActiveMQ ActiveMQ介绍 官方网站:http://activemq.apache.org/ 最新版本:ActiveMQ 5.14.1(2016-10-28) 最新版本下载链接:htt ...
- 谈谈SQL 语句的优化技术
https://blogs.msdn.microsoft.com/apgcdsd/2011/01/10/sql-1/ 一.引言 一个凸现在很多开发者或数据库管理员面前的问题是数据库系统的性能问题.性能 ...
- Android学习——windows下搭建NDK_r9环境
1. NDK(Native Development Kit) 1.1 NDK简介 Android NDK是一套允许开发人员使用本地代码(如C/C++)进行Android APP功能开发的工具,通过这个 ...
- java web学习总结(六) -------------------servlet开发(二)
一.ServletConfig讲解 1.1.配置Servlet初始化参数 在Servlet的配置文件web.xml中,可以使用一个或多个<init-param>标签为servlet配置一些 ...
- 深入理解C++对象模型
C++对象模型是比较重要的一个知识点,学习C++对象的内存模型,就可以明白C++中的多态原理.类的初始化顺序问题.类的大小问题等. 1 C++对象模型基础 1.1 C++对象中都有哪些东东 C++对象 ...
- servlet(二)
一.ServletConfig讲解 1.1.配置Servlet初始化参数 在Servlet的配置文件web.xml中,可以使用一个或多个<init-param>标签为servlet配置一些 ...
随机推荐
- iptables-save命令
[root@localhost ~]# iptables-save -t filter > iptables.bak [root@localhost ~]# cat iptables.bak # ...
- mdadm语法
mdadm命令详解及实验过程 一.概念 mdadm是multiple devices admin的简称,它是Linux下的一款标准的软件 RAID 管理工具,作者是Neil Brown 二.特点 ...
- python 操作手机
https://blog.csdn.net/wave_1102/article/details/41630469 import os import time import subprocess i = ...
- 2018-计算机系机试(第二批)-B-二进制输出
B. 二进制输出 单点时限: 1.0 sec 内存限制: 256 MB 输入一个十进制表示的非负整数,输出其 8 位二进制表示. 例如:输入 10 ,输出 00001010. 输入格式 一行一个非负整 ...
- C# TCP与UDP
Http使用端口是80 SMTP使用端口是25 TCP是首选协议,它提供有保证的传输.错误校正和缓冲. System.Net.Sockets. TcpClient类封装了TCP链接,提供属性字段来控制 ...
- 面试中linux常见的20个命令
1.查找文件 find / -name filename.txt 根据名称查找/目录下的filename.txt文件. 2.查看一个程序是否运行 ps –ef|grep tomcat 查看所有有关to ...
- 使用SQLsever批量查询TXT文本中的值
测试文档如下,需要查到case_no值为以下时,对应的单据信息分别是什么. 步骤如下: 在txt文本中 Ctrl+H,输入如下,点击“全部替换” 在word文本中,复制以上信息到word文本中,目的是 ...
- 在Netbeans的项目中添加JDBC驱动程序
想要使用Java连接MySQL数据库,必须在环境中加入配置JDBC驱动程序 Netbeans中添加JDBC的过程是: 1.首先需要下载JDBC 在百度中搜索“mysqljdbc驱动下载”,找到官网 或 ...
- ubuntu apt 安装 mpv
安装 curl -s https://non-gnu.uvt.nl/debian/uvt_key.gpg | sudo apt-key add - sudo add-apt-repository &q ...
- 用awk检查报表的列数
用awk检查报表的列数 前提当然是报表都有相同数量的列 less yourfile|awk ‘{print NF;exit;}’ NF是awk的内置变量,表示当前记录里域的个数,不难看出,这个命令实际 ...