博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
bzoj千题计划239:bzoj4069: [Apio2015]巴厘岛的雕塑
阅读量:5036 次
发布时间:2019-06-12

本文共 2403 字,大约阅读时间需要 8 分钟。

 

a!=1:

从高位到低位一位一位的算

记录下哪些位必须为0

dp[i][j] 表示前i个数分为j组,这一位为0,且满足之前必须为0的位也是0 是否可行

枚举k,表示k+1~i分为一组

若k+1~i的和满足 必须为0的位是0,且dp[k][j-1] 为true

则dp[i][j]为true

 

a=1:

从高位到低位一位一位的算

记录下哪些位必须为0

dp[i] 表示前i个数,这一位为0,且满足之前必须为0的位也是0,最少能划分的组数

枚举k,表示k+1~i划分为一组

若k+1~i的和满足 必须为0的位是0,且dp[k]合法,dp[i]=min{ dp[k] }+1

 

#include
#include
#include
#define N 2001using namespace std;typedef long long LL;int n,a,b;LL sum[N];LL zero,ans;bool dp1[N][N];int dp2[N];template
void read(T &x){ x=0; char c=getchar(); while(!isdigit(c)) c=getchar(); while(isdigit(c)) { x=x*10+c-'0'; c=getchar(); }}bool judge(int l,int r,int t){ LL s=sum[r]-sum[l-1]; return !(zero&s) && !(s&(1LL<
=0;--t) { memset(dp1,false,sizeof(dp1)); dp1[0][0]=true; for(int i=1;i<=n;++i) for(int j=1;j<=b;++j) for(int k=0;k
=0;--t) { memset(dp2,63,sizeof(dp2)); dp2[0]=0; for(int i=1;i<=n;++i) for(int j=0;j

 

4069: [Apio2015]巴厘岛的雕塑

Time Limit: 10 Sec  Memory Limit: 64 MB
Submit: 466  Solved: 228
[][][]

Description

印尼巴厘岛的公路上有许多的雕塑,我们来关注它的一条主干道。
在这条主干道上一共有 N 座雕塑,为方便起见,我们把这些雕塑从 1 到 N 连续地进行标号,其中第 i 座雕塑的年龄是 Yi 年。为了使这条路的环境更加优美,政府想把这些雕塑分成若干组,并通过在组与组之间种上一些树,来吸引更多的游客来巴厘岛。
下面是将雕塑分组的规则:
这些雕塑必须被分为恰好 X 组,其中 A< = X< = B,每组必须含有至少一个雕塑,每个雕塑也必须属于且只属于一个组。同一组中的所有雕塑必须位于这条路的连续一段上。
当雕塑被分好组后,对于每个组,我们首先计算出该组所有雕塑的年龄和。
计算所有年龄和按位取或的结果。我们这个值把称为这一分组的最终优美度。
请问政府能得到的最小的最终优美度是多少?
备注:将两个非负数 P 和 Q 按位取或是这样进行计算的:
首先把 P 和 Q 转换成二进制。
设 nP 是 P 的二进制位数,nQ 是 Q 的二进制位数,M 为 nP 和 nQ 中的最大值。P 的二进制表示为 pM−1pM−2…p1p0,Q 的二进制表示为 qM−1qM−2…q1q0,其中 pi 和 qi 分别是 P 和 Q 二进制表示下的第 i 位,第 M−1 位是数的最高位,第 0 位是数的最低位。
P 与 Q 按位取或后的结果是: (pM−1  OR  qM−1)(pM−2 OR qM−2)…(p1 OR q1)(p0 OR q0)。其中:
0 OR 0=0
0 OR 1=1
1 OR 0=1
1 OR 1=1
 
 

Input

输入的第一行包含三个用空格分开的整数 N,A,B。

 
第二行包含 N 个用空格分开的整数 Y1,Y2,…,YN。
 

Output

输出一行一个数,表示最小的最终优美度。

 

Sample Input

6 1 3
8 1 2 1 5 4

Sample Output

11
explanation
将这些雕塑分为 2 组,(8,1,2) 和 (1,5,4),它们的和是 (11) 和 (10),最终优美度是 (11 OR 10)=11。(不难验证,这也是最终优美度的最小值。)

HINT

 

 子任务 1 (9 分)

1< = N< = 20
1< = A< = B< = N
0< = Yi< = 1000000000
子任务 2 (16 分)
1< = N< = 50
1< = A< = B< = min{20,N}
0< = Yi< = 10
子任务 3 (21 分)
1< = N< = 100
A=1
1< = B< = N
0< = Yi< = 20
子任务 4 (25 分)
1< = N< = 100
1< = A< = B< = N
0< = Yi< = 1000000000
子任务 5 (29 分)
1< = N< = 2000
A=1
1< = B< = N
0< = Yi< = 1000000000

转载于:https://www.cnblogs.com/TheRoadToTheGold/p/8454382.html

你可能感兴趣的文章
Spring MVC JSON 实现JsonSerializer Date类型转换
查看>>
Citrix 服务器虚拟化之十 Xenserver高可用性HA
查看>>
三层架构与MVC
查看>>
js原生appendChild的bug
查看>>
在word 中复选框划勾或叉的方法
查看>>
工厂模式
查看>>
比例运算和求和电路
查看>>
Luogu P3927 SAC E#1 - 一道中档题 Factorial
查看>>
scrapy框架初识
查看>>
卡片游戏
查看>>
bat 获取当前目录的父目录
查看>>
RocksDB系列二十二:RocksDB使用场景和特性
查看>>
WordPress插件开发教程:(一)插件简介
查看>>
Android学习笔记之View(一):LayoutInflater
查看>>
.net core 发布到docker
查看>>
web移动端浮层滚动阻止window窗体滚动JS/CSS处理
查看>>
字符串匹配的KMP算法-16张图片看明白
查看>>
[机器学习]回归--Support Vector Regression(SVR)
查看>>
hdoj_3476Cyclic Nacklace
查看>>
2019-05-23 奇虎ARP防火墙
查看>>