[APIO2015]巴厘岛的雕塑 --- 贪心 + 枚举
[APIO2015]巴厘岛的雕塑
题目描述
印尼巴厘岛的公路上有许多的雕塑,我们来关注它的一条主干道。
在这条主干道上一共有\(N\)座雕塑,为方便起见,我们把这些雕塑从 1 到\(N\)连续地进行标号,其中第\(i\)座雕塑的年龄是\(Y_{i}\)年。
为了使这条路的环境更加优美,政府想把这些雕塑分成若干组,并通过在组与组之间种上一些树,来吸引更多的游客来巴厘岛。
下面是将雕塑分组的规则:
这些雕塑必须被分为恰好\(X\)组,其中 \(A<=X<=B\),每组必须含有至少一个雕塑,每个雕塑也必须属于且只属于一个组。
同一组中的所有雕塑必须位于这条路的连续一段上。
当雕塑被分好组后,对于每个组,我们首先计算出该组所有雕塑的年龄和。
计算所有年龄和按位取或的结果。我们这个值把称为这一分组的最终优美度。
请问政府能得到的最小的最终优美度是多少?
数据范围:

或值最大 ---) 按位贪心即可
为了保证最小,从高位向低位贪心(虽然最大是一样的。。。)
那么怎么确定最小的答案呢?
注意到,高位贪心的结果需要被保留(高位一定更优)。
因此,维护\(dp(i,j)\)表示枚举到第\(i\)位,分成了\(j\)块,能否在满足高位贪心的同时可不可以让当前位为0。
如果\(dp(n,A)...dp(n,B)\)中有一个满足,那么当前位可以为0,计入高位。
如何转移?
枚举即可,枚举所有的区间来转移,确定一位能否为0需要\(n^{2}*B\)时间
总共需要时间\(O(\log n *B*n^{2})\)
可以发现过不掉最后一个点。
但是\(A=1\)非常的显眼,有什么用?
这告诉我们没有下届,只有上届。
因此,只要求出至少需要多少块才能在满足高位贪心的同时让当前位为0,同样可以判断。
复杂度可以降至:
\(O(\log n * n ^{2})\)
#include <cstdio>
#include <cstring>
#define ll long long
#define ri register int
using namespace std; char RR[], *S = RR, *T = RR + ;
inline char gc() {
if(S == T) fread(RR, , , stdin), S = RR;
return *S ++;
}
inline int read() {
int p = , w = ; char c = gc();
while(c > '' || c < '') {
if(c == '-') w = -;
c = gc();
}
while(c >= '' && c <= '') {
p = p * + c - '';
c = gc();
}
return p;
} template <typename re>
inline void upmin(re &a, re b) { if(a > b) a = b; } int n, A, B;
ll ans, sum[], bit[];
bool dp[][];
int f[]; void Solve1() {
for(ri p = ; p; p --) {
memset(dp, , sizeof(dp));
dp[][] = ;
for(ri i = ; i <= n; i ++)
for(ri j = ; j <= i; j ++)
for(ri k = j - ; k <= i - ; k ++)
if(dp[k][j - ]) {
ll pp = sum[i] - sum[k];
if(((pp >> p) | ans) == ans)
if((pp & bit[p - ]) == ) dp[i][j] = ;
}
ans <<= ; ans |= ;
for(ri i = A; i <= B; i ++)
if(dp[n][i]) { ans ^= ; break; }
}
printf("%lld\n", ans);
} void Solve2() {
for(ri p = ; p; p --) {
for(ri i = ; i <= n; i ++) f[i] = ;
for(ri i = ; i <= n; i ++)
for(ri j = ; j <= i - ; j ++) {
ll pp = sum[i] - sum[j];
if(((pp >> p) | ans) == ans)
if((pp & bit[p - ]) == ) upmin(f[i], f[j] + );
}
ans <<= ;
if(f[n] > B) ans |= ;
}
printf("%lld\n", ans);
} int main() {
for(ri i = ; i <= ; i ++) bit[i] = 1LL << i;
n = read(); A = read(); B = read();
for(ri i = ; i <= n; i ++) sum[i] = sum[i - ] + read();
if(A == ) Solve2();
else Solve1();
return ;
}
Aha!
[APIO2015]巴厘岛的雕塑 --- 贪心 + 枚举的更多相关文章
- [APIO2015]巴厘岛的雕塑 贪心+DP+特殊数据优化
写了好久.... 刚刚调了一个小时各种对拍,,,,最后发现是多写了一个等号,,,,内心拒绝 表示一开始看真的是各种懵逼啊 在偷听到某位大佬说的从高位开始贪心后发现可做 首先考虑小数据(因为可以乱搞) ...
- BZOJ 4069 [Apio2015]巴厘岛的雕塑 ——贪心
自己首先想了一种方法$f(i)$表示前$i$个最小值为多少. 然而发现位运算并不满足局部最优性. 然后我们可以从高到低贪心的判断,使得每一组的和在一个特定的范围之内. 还要特判最后一个Subtask, ...
- 【BZOJ4069】[Apio2015]巴厘岛的雕塑 按位贪心+DP
[BZOJ4069][Apio2015]巴厘岛的雕塑 Description 印尼巴厘岛的公路上有许多的雕塑,我们来关注它的一条主干道. 在这条主干道上一共有 N 座雕塑,为方便起见,我们把这些雕塑从 ...
- bzoj 4069 [Apio2015]巴厘岛的雕塑 dp
[Apio2015]巴厘岛的雕塑 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 494 Solved: 238[Submit][Status][Dis ...
- bzoj千题计划239:bzoj4069: [Apio2015]巴厘岛的雕塑
http://www.lydsy.com/JudgeOnline/problem.php?id=4069 a!=1: 从高位到低位一位一位的算 记录下哪些位必须为0 dp[i][j] 表示前i个数分为 ...
- 【BZOJ4069】【APIO2015】巴厘岛的雕塑 [贪心][DP]
巴厘岛的雕塑 Time Limit: 10 Sec Memory Limit: 64 MB[Submit][Status][Discuss] Description 印尼巴厘岛的公路上有许多的雕塑, ...
- [APIO2015]巴厘岛的雕塑[按位贪心+dp]
题意 给你长度为 \(n\) 的序列,要求分成 \(k\) 段连续非空的区间,求所有区间和的 \(or\) 最小值. 分析 定义 \(f_{i,j}\) 表示前 \(i\) 个点分成 \(j\) 段的 ...
- 4069: [Apio2015]巴厘岛的雕塑
Description 印尼巴厘岛的公路上有许多的雕塑,我们来关注它的一条主干道. 在这条主干道上一共有 N 座雕塑,为方便起见,我们把这些雕塑从 1 到 N 连续地进行标号,其中第 i 座雕塑的年龄 ...
- [APIO2015]巴厘岛的雕塑
题目描述 印尼巴厘岛的公路上有许多的雕塑,我们来关注它的一条主干道. 在这条主干道上一共有 NN 座雕塑,为方便起见,我们把这些雕塑从 11 到 NN 连续地进行标号,其中第 ii 座雕塑的年龄是 Y ...
随机推荐
- js小记:对象、原型及原型链、面向对象编程
一.js对象 1.js对象 js对象是一种复合数据类型,它可以把多个(不同类型的)数据集中在一个变量中,并且给每个数据起名字. 2.对象与数组 对象的每个数据有对应的名字(属性名),我们通过叫名字访问 ...
- [NOIP2003]栈 题解(卡特兰数)
[NOIP2003]栈 Description 宁宁考虑的是这样一个问题:一个操作数序列,从1,2,一直到n(图示为1到3的情况),栈A的深度大于n. 现在可以进行两种操作: 1.将一个数,从操作数序 ...
- itext 生成pdf文件添加页眉页脚
原文来自:https://www.cnblogs.com/joann/p/5511905.html 我只是记录所有jar版本,由于版本冲突及不兼容很让人头疼的,一共需要5个jar, 其中itextpd ...
- SSL证书生成方法【转】
转自 SSL证书生成方法 - fyang的专栏 - 博客频道 - CSDN.NEThttp://blog.csdn.net/fyang2007/article/details/6180361 一般情况 ...
- [转载]FFmpeg完美入门[3] - FFmpeg功能及使用说明
1 ffplay对多媒体的支持能力验证 一.视频3gp 177X144 支持播放,在windows下播放正常,但是在linux下面偶有BUG 如果发现画面无法显示而声音可以播放的情况下可以试着切换全屏 ...
- Vue.js写一个SPA登录页面的过程
技术栈 vue.js 主框架 vuex 状态管理 vue-router 路由管理 一般过程 在一般的登录过程中,一种前端方案是: 检查状态:进入页面时或者路由变化时检查是否有登录状态(保存在cooki ...
- 使用keytool生成ssl密钥文件keystore和truststore
最近在研究Mina的开发,通信的时候需要数据加密,而且mina本身支持SSLFilter过滤器,所以可以采用SSL加密的方式对数据进行加密. 在进行加密之前,我们需要使用keytool(这个存在于C: ...
- linux系统性能排查命令
[top] 命令可以动态查看当前系统的资源情况,以及占用资源的命令列表 用法: - ctrl + c / q : 停止此命令运行 - c : 展示完整的命令 - [top -bn1]:可以不动态的展示 ...
- TypeError: not all arguments converted during string formatting
print ("So, you're 5r old, %r tall and %r heavy." % (age, height, weight)) print ("So ...
- centos7安装完成后的一些配置
1.打开终端 输入 sudo yum -y update 先更新软件包 2.这是输入语言 应用程序->系统工具->设置->区域和语言->+ ->汉语(中国)-> ...