[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]巴厘岛的雕塑 --- 贪心 + 枚举的更多相关文章

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

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

  2. BZOJ 4069 [Apio2015]巴厘岛的雕塑 ——贪心

    自己首先想了一种方法$f(i)$表示前$i$个最小值为多少. 然而发现位运算并不满足局部最优性. 然后我们可以从高到低贪心的判断,使得每一组的和在一个特定的范围之内. 还要特判最后一个Subtask, ...

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

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

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

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

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

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

  6. 【BZOJ4069】【APIO2015】巴厘岛的雕塑 [贪心][DP]

    巴厘岛的雕塑 Time Limit: 10 Sec  Memory Limit: 64 MB[Submit][Status][Discuss] Description 印尼巴厘岛的公路上有许多的雕塑, ...

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

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

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

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

  9. [APIO2015]巴厘岛的雕塑

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

随机推荐

  1. 【BZOJ】1834 [ZJOI2010]network 网络扩容

    [算法]网络流-最大流+最小费用最大流(费用流) [题解] 第一问跑最大流. 第二问: 原始边相当于费用为0的边,再原图(跑过最大流的图)基础上添加带费用的边,容量为k(相当于inf). 第一问最大流 ...

  2. jsoup抓取网页报错UnsupportedMimeTypeException

    今天在用Jsoup爬虫的时候两次遇到下面错误 Exception in thread "main" org.jsoup.UnsupportedMimeTypeException: ...

  3. 笔记本自开wifi设置

    笔记本自开wifi设置 是这样的有些笔记本他自身就可以放出热点供其他的小伙伴们连接,不用非得去下专门的工具有些笔记本的网卡是自带支持双收发的(这里注意我指的是有些笔记本不是全部) 命令我已经写出来了  ...

  4. Ural Sport Programming Championship 2015

    Ural Sport Programming Championship 2015 A - The First Day at School 题目描述:给出课程安排,打印一个课程表. solution 暴 ...

  5. windows安装React Native开发运行环境

    React Native是什么 React Native是facebook开源的一个用于开发app的框架.React Native的设计理念:既拥有Native (原生) 的用户体验.又保留React ...

  6. TreeSet基本用法

    TreeSet的基础方法: public class TreeSetTest { public static void main(String[] args) { TreeSet nums = new ...

  7. java中常见异常汇总(根据自己遇到的异常不定时更新)

    1.java.lang.ArrayIndexOutOfBoundsException:N(数组索引越界异常.如果访问数组元素时指定的索引值小于0,或者大于等于数组的长度,编译程序不会出现任何错误,但运 ...

  8. ASP连接读写ACCESS数据库实例(转)

    (一)   数据库的选择:有许多的数据库你可以选择,SQL SERVER.ACCESS(*.mdb).EXCEL(*.xls).FOXPRO(*.dbf)甚至普通的文本文件(*.txt)都可以达到存储 ...

  9. Percona XtraDB Cluster(PXC)-高可用架构设计说明

    Mycat+PXC高可用集群 一.架构图 架构说明: 1.mysql 集群高可用部分: l 针对业务场景选用Percona XtraDB Cluter(PXC)复制集群.两个片集群 PXC-dataN ...

  10. Pylint在项目中的使用

    需求背景: Pylint 是一个 Python 代码分析工具,它分析 Python 代码中的错误,查找不符合代码风格标准和有潜在问题的代码. Pylint 是一个 Python 工具,除了平常代码分析 ...