题目大意

分成 \(x\) 堆,是的每堆的和的异或值最小

分析

这是一道非常简单的数位 \(DP\) 题

基于贪心思想,我们要尽量让最高位的 \(1\) 最小, 因此我们考虑从高位向低位进行枚举,看是否存在一种方案使得最高为不为 \(1\),如果不存在,那就填 \(1\)

因此我们要解决如下问题:

  1. 保存之前的状态
  2. 考虑 \(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]巴厘岛的雕塑的更多相关文章

  1. bzoj千题计划239:bzoj4069: [Apio2015]巴厘岛的雕塑

    http://www.lydsy.com/JudgeOnline/problem.php?id=4069 a!=1: 从高位到低位一位一位的算 记录下哪些位必须为0 dp[i][j] 表示前i个数分为 ...

  2. 【BZOJ4069】[Apio2015]巴厘岛的雕塑 按位贪心+DP

    [BZOJ4069][Apio2015]巴厘岛的雕塑 Description 印尼巴厘岛的公路上有许多的雕塑,我们来关注它的一条主干道. 在这条主干道上一共有 N 座雕塑,为方便起见,我们把这些雕塑从 ...

  3. [APIO2015]巴厘岛的雕塑 --- 贪心 + 枚举

    [APIO2015]巴厘岛的雕塑  题目描述 印尼巴厘岛的公路上有许多的雕塑,我们来关注它的一条主干道. 在这条主干道上一共有\(N\)座雕塑,为方便起见,我们把这些雕塑从 1 到\(N\)连续地进行 ...

  4. bzoj 4069 [Apio2015]巴厘岛的雕塑 dp

    [Apio2015]巴厘岛的雕塑 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 494  Solved: 238[Submit][Status][Dis ...

  5. 4069: [Apio2015]巴厘岛的雕塑

    Description 印尼巴厘岛的公路上有许多的雕塑,我们来关注它的一条主干道. 在这条主干道上一共有 N 座雕塑,为方便起见,我们把这些雕塑从 1 到 N 连续地进行标号,其中第 i 座雕塑的年龄 ...

  6. [APIO2015]巴厘岛的雕塑

    题目描述 印尼巴厘岛的公路上有许多的雕塑,我们来关注它的一条主干道. 在这条主干道上一共有 NN 座雕塑,为方便起见,我们把这些雕塑从 11 到 NN 连续地进行标号,其中第 ii 座雕塑的年龄是 Y ...

  7. Luogu P3646 [APIO2015]巴厘岛的雕塑

    深夜写题解系列,话说这题暑假的时候就在LOJ上做掉了,然后今天看到Luogu上有就去交了一下,发现没写过题解,赶紧来补一下 说句题外话APIO2015的题目好水啊 首先考虑按位取或的过程,很显然要从二 ...

  8. [APIO2015]巴厘岛的雕塑[按位贪心+dp]

    题意 给你长度为 \(n\) 的序列,要求分成 \(k\) 段连续非空的区间,求所有区间和的 \(or\) 最小值. 分析 定义 \(f_{i,j}\) 表示前 \(i\) 个点分成 \(j\) 段的 ...

  9. [APIO2015]巴厘岛的雕塑 贪心+DP+特殊数据优化

    写了好久.... 刚刚调了一个小时各种对拍,,,,最后发现是多写了一个等号,,,,内心拒绝 表示一开始看真的是各种懵逼啊 在偷听到某位大佬说的从高位开始贪心后发现可做 首先考虑小数据(因为可以乱搞) ...

随机推荐

  1. 【BZOJ1717】[Usaco2006 Dec]Milk Patterns 产奶的模式 后缀数组

    [BZOJ1717][Usaco2006 Dec]Milk Patterns Description 农夫John发现他的奶牛产奶的质量一直在变动.经过细致的调查,他发现:虽然他不能预见明天产奶的质量 ...

  2. python下几种打开文件的方式

    昨天看完了这本python进阶,感觉这本书对我启发很大,做了三张纸的笔记,方便我在遇到问题的时候翻阅,然后寻找可能的解决方案.作为一个使用Python一年的小白,虽然说不是小白,但是这一年来基本上是用 ...

  3. CentOS7安装步骤详解

    准备环境 1.虚拟机  VMware Workstation 2.Centos7-64位安装包  ( CentOS-6.7-x86_64-bin-DVD1.iso ) 开始安装   进入安装初始化界面 ...

  4. 【node】------module.exports&&exports之间的区别------【巷子】

    1.再讲module.exports 与exports之间的区别的时候我们先来回顾一下js里面的引用传递 001.引用传递 var arr = [10,20,30]; var newarr = arr ...

  5. 170616、解决 java.lang.IllegalArgumentException: No converter found for return value of type: class java.util.ArrayList

    报错截图: 原因:搭建项目的时候,springmvc默认是没有对象转换成json的转换器的,需要手动添加jackson依赖. 解决步骤: 1.添加jackson依赖到pom.xml <!-- j ...

  6. Python使用pyMysql模块插入数据到mysql的乱码解决

    1.初步安装mysql,插入中文字符,出现的???的形式 终端提示: pymysql.err.InternalError: (1366, "Incorrect string value: ' ...

  7. 构建vue项目(vue 2.x)时的一些配置问题(持续更新)

    基于前文,使用vue-cli脚手架工具构建项目,并使用了webpack,那么我在项目中遇到的一些与配置相关的问题将在这里进行汇总. 1.代码检查问题 由于我们在构建项目时,使用了Eslint对我们的项 ...

  8. Python开发【项目】:RPC异步执行命令(RabbitMQ双向通信)

    RPC异步执行命令 需求: 利用RibbitMQ进行数据交互 可以对多台服务器进行操作 执行命令后不等待命令的执行结果,而是直接让输入下一条命令,结果出来后自动打印 实现异步操作 不懂rpc的请移步h ...

  9. DIY自己的GIS程序(2)——局部刷新

    绘制线过移动鼠标程中绘制临时线段防闪烁 参考OpenS-CAD想实现绘制线的功能.希望实现绘制线的过程,在移动线的时候没有闪烁和花屏.但是出现了问题,困扰了2天,前天熬的太晚,搞得现在精力都没有恢复. ...

  10. VS2010/MFC编程入门之十二(对话框:非模态对话框的创建及显示)

    上一节鸡啄米讲了模态对话框及其弹出过程,本节接着讲另一种对话框--非模态对话框的创建及显示. 鸡啄米已经说过,非模态对话框显示后,程序其他窗口仍能正常运行,可以响应用户输入,还可以相互切换.鸡啄米会将 ...