[BZOJ4069][Apio2015]巴厘岛的雕塑
题目大意
分成 \(x\) 堆,是的每堆的和的异或值最小
分析
这是一道非常简单的数位 \(DP\) 题
基于贪心思想,我们要尽量让最高位的 \(1\) 最小, 因此我们考虑从高位向低位进行枚举,看是否存在一种方案使得最高为不为 \(1\),如果不存在,那就填 \(1\)
因此我们要解决如下问题:
- 保存之前的状态
- 考虑 \(A\), \(B\) 的限制
我们设已经考虑到 \(x\) 位,并且当前的值为 \(ans\)
显然如果该位可以不填,它必须满足存在一种状态使得之前已经决定的状态的异或和为 \(ans\), 并且新增的一段不会使得 \(ans\) 改变
那这就是一个经典的区间DP问题
我们不妨设 \(f[i][j]\) 表示前 \(i\) 个数分成 \(j\) 段,是否存在这一种情况
如果满足上述条件,我们就能够从 \(f[k][j - 1]\) 转移到 \(f[i][j]\)
对于每个一位,如果有一种给情况使得当前为为0,那就让 \(ans\) 的当前位为 \(0\)
复杂度:\(O(n^3logD)\)
对于最后一组数据:\(A =1, B \le n\),段数只有上限
我们要想把 \(f\) 数组的第二个维度省掉的话,用 \(f[i]\) 记录将前 \(i\) 个数分段并得到可行解的最小段数,最后判断其是否小于 \(B\),即可
复杂度:\(O(n^2logD)\)
总结
想了半天发现 \(O(n^3logD)\) 没办法优化,结果发现最后一个点的 \(A = 1\)。
const int maxn = 2018;
typedef long long LL;
LL s[maxn];
int f[maxn][maxn], g[maxn];
LL ans = 0, t;
int n, A, B, len = 0;
bool valid(LL val, int dig) {
return ((val >> (LL)dig | ans) == ans && (val & 1LL << (LL)dig-1LL) == 0);
}
void work1() {
for(int x = len; x > 0; -- x) {
forn(i, n) g[i] = INF;
forn(i, n) Forn(j, i) if (g[j] < B) {
t = s[i] - s[j];
if(valid(t, x)) if (g[j] + 1 < g[i]) g[i] = g[j] + 1;
}
ans <<= 1LL;
if(g[n] > B) ans ++;
}
}
void work2() {
for(int x = len; x > 0; -- x) {
memset(f, 0, sizeof(f));
f[0][0] = 1;
forn(i, n) forn(j, i) for (int k = 0; k < i; ++ k) if(f[k][j-1]) {
t = s[i] - s[k];
//printf("x = %d i = %d j = %d k = %d t = %d\n", x, i, j, k, t);
if(valid(t, x)) f[i][j] = 1;
}
int i;
for(i = A; i <= B; ++ i) {
if(f[n][i]) break;
}
ans <<= 1LL;
if(i > B) ans ++;
}
}
int main() {
read(n, A, B);
forn(i, n) {
read(s[i]); s[i] += s[i-1];
}
len = (int)log2(s[n]) + 1;
if (A == 1) work1();
else work2();
printf("%lld", ans);
return 0;
}
[BZOJ4069][Apio2015]巴厘岛的雕塑的更多相关文章
- bzoj千题计划239:bzoj4069: [Apio2015]巴厘岛的雕塑
http://www.lydsy.com/JudgeOnline/problem.php?id=4069 a!=1: 从高位到低位一位一位的算 记录下哪些位必须为0 dp[i][j] 表示前i个数分为 ...
- 【BZOJ4069】[Apio2015]巴厘岛的雕塑 按位贪心+DP
[BZOJ4069][Apio2015]巴厘岛的雕塑 Description 印尼巴厘岛的公路上有许多的雕塑,我们来关注它的一条主干道. 在这条主干道上一共有 N 座雕塑,为方便起见,我们把这些雕塑从 ...
- [APIO2015]巴厘岛的雕塑 --- 贪心 + 枚举
[APIO2015]巴厘岛的雕塑 题目描述 印尼巴厘岛的公路上有许多的雕塑,我们来关注它的一条主干道. 在这条主干道上一共有\(N\)座雕塑,为方便起见,我们把这些雕塑从 1 到\(N\)连续地进行 ...
- bzoj 4069 [Apio2015]巴厘岛的雕塑 dp
[Apio2015]巴厘岛的雕塑 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 494 Solved: 238[Submit][Status][Dis ...
- 4069: [Apio2015]巴厘岛的雕塑
Description 印尼巴厘岛的公路上有许多的雕塑,我们来关注它的一条主干道. 在这条主干道上一共有 N 座雕塑,为方便起见,我们把这些雕塑从 1 到 N 连续地进行标号,其中第 i 座雕塑的年龄 ...
- [APIO2015]巴厘岛的雕塑
题目描述 印尼巴厘岛的公路上有许多的雕塑,我们来关注它的一条主干道. 在这条主干道上一共有 NN 座雕塑,为方便起见,我们把这些雕塑从 11 到 NN 连续地进行标号,其中第 ii 座雕塑的年龄是 Y ...
- Luogu P3646 [APIO2015]巴厘岛的雕塑
深夜写题解系列,话说这题暑假的时候就在LOJ上做掉了,然后今天看到Luogu上有就去交了一下,发现没写过题解,赶紧来补一下 说句题外话APIO2015的题目好水啊 首先考虑按位取或的过程,很显然要从二 ...
- [APIO2015]巴厘岛的雕塑[按位贪心+dp]
题意 给你长度为 \(n\) 的序列,要求分成 \(k\) 段连续非空的区间,求所有区间和的 \(or\) 最小值. 分析 定义 \(f_{i,j}\) 表示前 \(i\) 个点分成 \(j\) 段的 ...
- [APIO2015]巴厘岛的雕塑 贪心+DP+特殊数据优化
写了好久.... 刚刚调了一个小时各种对拍,,,,最后发现是多写了一个等号,,,,内心拒绝 表示一开始看真的是各种懵逼啊 在偷听到某位大佬说的从高位开始贪心后发现可做 首先考虑小数据(因为可以乱搞) ...
随机推荐
- POJ 3461 Oulipo[附KMP算法详细流程讲解]
E - Oulipo Time Limit:1000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u Submit ...
- nutch 1.7导入Eclipse
1.下载Nutch1.7的包 apache-nutch-1.7-src.zip,解压之后应该包括 bin,conf,src等目录 2.将解压之后的 apache-nutch-1.7 文件夹放到ecli ...
- 【BZOJ5082】弗拉格 矩阵乘法
[BZOJ5082]弗拉格 Description “如果明天进了面试,我就去爆妹子的照”——有妹子的丁相允作为一个oier,自然不能立太多flag,让我们来看一道和flag有关的题目吧 给你n个fl ...
- talib 中文文档(十四):Math Transform Functions 数学变换
Math Transform Functions ACOS - Vector Trigonometric ACos 函数名:ACOS 名称:acos函数是反余弦函数,三角函数 real = ACOS( ...
- stark - 分页、search、actions
一.分页 效果图 知识点 1.分页 {{ showlist.pagination.page_html|safe }} 2.page.py class Pagination(object): def _ ...
- arpa/inet.h所引起的Segmentation fault及网络编程常见的头文件
最近在学习Linux网络编程方面的知识,感觉还是有些困难.主要是对协议过程的理解,还有socket的API的理解不够深刻.今天复习编写了一个TCP的服务端和客户端的程序实现client.c从命令行参数 ...
- 第1章 1.2计算机网络概述--Intenet和广域网
1.ISP Internet服务提供商,也称ISP运营商.如:在中国,电信.网通.长城宽带. ISP运营商内部的网络连接十分发达,但是不同ISP运营商之间的连接的线路非常有限,这就导致了跨运营商访问网 ...
- mysql 数据操作 单表查询 where约束 is null in
需求找出年龄是 81 或者 73 或者 28 mysql ; +----+-----------+--------+-----+------------+-----------+----------- ...
- Log表新的RowKey设计,预Split
1 目前Rawlog表的问题 region数量庞大,空region 率大 共有12791个region 11409空region, 比例为89.19% 剩余的region大小也是极度不均衡,最大的re ...
- 解决FlexPaper分页分段加载问题(转)
FlexPaper是一个开源的PDF文档在线查看控件.用户查看PDF文档不需要安装Acrobat Reader,但需要利用像SwfTools这样的工具预先将PDF文档转成SWF格式的文件.FlexPa ...