bzoj千题计划239:bzoj4069: [Apio2015]巴厘岛的雕塑
http://www.lydsy.com/JudgeOnline/problem.php?id=4069
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<cstdio>
#include<cstring>
#include<iostream> #define N 2001 using namespace std; typedef long long LL; int n,a,b;
LL sum[N]; LL zero,ans; bool dp1[N][N]; int dp2[N]; template<typename T>
void read(T &x)
{
x=; char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) { x=x*+c-''; c=getchar(); }
} bool judge(int l,int r,int t)
{
LL s=sum[r]-sum[l-];
return !(zero&s) && !(s&(1LL<<t));
} void solve1()
{
for(int t=;t>=;--t)
{
memset(dp1,false,sizeof(dp1));
dp1[][]=true;
for(int i=;i<=n;++i)
for(int j=;j<=b;++j)
for(int k=;k<i;++k)
if(dp1[k][j-] && judge(k+,i,t)) dp1[i][j]=true;
int j;
for(j=a;j<=b;++j)
if(dp1[n][j])
{
zero+=1LL<<t;
break;
}
if(j==b+) ans+=1LL<<t;
}
} void solve2()
{
for(int t=;t>=;--t)
{
memset(dp2,,sizeof(dp2));
dp2[]=;
for(int i=;i<=n;++i)
for(int j=;j<i;++j)
if(dp2[j]!=- && judge(j+,i,t)) dp2[i]=min(dp2[i],dp2[j]+);
if(dp2[n]<=b) zero+=1LL<<t;
else ans+=1LL<<t;
}
} int main()
{
//freopen("sculpture.in","r",stdin);
//freopen("sculpture.out","w",stdout);
read(n); read(a); read(b);
for(int i=;i<=n;++i) read(sum[i]),sum[i]+=sum[i-];
if(a!=) solve1();
else solve2();
cout<<ans;
}
4069: [Apio2015]巴厘岛的雕塑
Time Limit: 10 Sec Memory Limit: 64 MB
Submit: 466 Solved: 228
[Submit][Status][Discuss]
Description
Input
输入的第一行包含三个用空格分开的整数 N,A,B。
Output
输出一行一个数,表示最小的最终优美度。
Sample Input
8 1 2 1 5 4
Sample Output
explanation
将这些雕塑分为 2 组,(8,1,2) 和 (1,5,4),它们的和是 (11) 和 (10),最终优美度是 (11 OR 10)=11。(不难验证,这也是最终优美度的最小值。)
HINT
子任务 1 (9 分)
bzoj千题计划239:bzoj4069: [Apio2015]巴厘岛的雕塑的更多相关文章
- bzoj千题计划300:bzoj4823: [Cqoi2017]老C的方块
http://www.lydsy.com/JudgeOnline/problem.php?id=4823 讨厌的形状就是四联通图 且左右各连一个方块 那么破坏所有满足条件的四联通就好了 按上图方式染色 ...
- bzoj千题计划196:bzoj4826: [Hnoi2017]影魔
http://www.lydsy.com/JudgeOnline/problem.php?id=4826 吐槽一下bzoj这道题的排版是真丑... 我还是粘洛谷的题面吧... 提供p1的攻击力:i,j ...
- bzoj千题计划280:bzoj4592: [Shoi2015]脑洞治疗仪
http://www.lydsy.com/JudgeOnline/problem.php?id=4592 注意操作1 先挖再补,就是补的范围可以包含挖的范围 SHOI2015 的题 略水啊(逃) #i ...
- bzoj千题计划177:bzoj1858: [Scoi2010]序列操作
http://www.lydsy.com/JudgeOnline/problem.php?id=1858 2018 自己写的第1题,一遍过 ^_^ 元旦快乐 #include<cstdio> ...
- bzoj千题计划317:bzoj4650: [Noi2016]优秀的拆分(后缀数组+差分)
https://www.lydsy.com/JudgeOnline/problem.php?id=4650 如果能够预处理出 suf[i] 以i结尾的形式为AA的子串个数 pre[i] 以i开头的形式 ...
- bzoj千题计划304:bzoj3676: [Apio2014]回文串(回文自动机)
https://www.lydsy.com/JudgeOnline/problem.php?id=3676 回文自动机模板题 4年前的APIO如今竟沦为模板,,,╮(╯▽╰)╭,唉 #include& ...
- bzoj千题计划292:bzoj2244: [SDOI2011]拦截导弹
http://www.lydsy.com/JudgeOnline/problem.php?id=2244 每枚导弹成功拦截的概率 = 包含它的最长上升子序列个数/最长上升子序列总个数 pre_len ...
- bzoj千题计划278:bzoj4590: [Shoi2015]自动刷题机
http://www.lydsy.com/JudgeOnline/problem.php?id=4590 二分 这么道水题 没long long WA了两发,没判-1WA了一发,二分写错WA了一发 最 ...
- bzoj千题计划250:bzoj3670: [Noi2014]动物园
http://www.lydsy.com/JudgeOnline/problem.php?id=3670 法一:KMP+st表 抽离nxt数组,构成一棵树 若nxt[i]=j,则i作为j的子节点 那么 ...
随机推荐
- 【ORACLE】碎片整理
alter table test enable row movement; alter table test shrink space; execute dbms_stats.gather_table ...
- .Net Core 分布式微服务框架 - Jimu 添加 Swagger 支持
系列文章 .Net Core 分布式微服务框架介绍 - Jimu .Net Core 分布式微服务框架 - Jimu 添加 Swagger 支持 一.前言 最近有空就优化 Jimu (一个基于.Net ...
- Scrapy的日志等级和请求传参
日志等级 日志信息: 使用命令:scrapy crawl 爬虫文件 运行程序时,在终端输出的就是日志信息: 日志信息的种类: ERROR:一般错误: WARNING:警告: INFO:一般的信息: ...
- Android 测试之Monkey
一.什么是Monkey Monkey是Android中的一个命令行工具,可以运行在模拟器里或实际设备中.它向系统发送伪随机的用户事件流(如按键输入.触摸屏输入.手势输入等),实现对正在开发的应用程序进 ...
- 机器学习初入门04 – Seaborn(持续更新)
Seaborn库可以说是在matplotlib库上的一个封装,它给我们提供了非常丰富的模板 一.整体布局风格设置 import seaborn as sns import numpy as np im ...
- Linux DDos防御
今天要说的就是一款能够自动屏蔽DDOS攻击者IP的软件:DDoS deflate. DDoS deflate介绍 DDoS deflate是一款免费的用来防御和减轻DDoS攻击的脚本.它通过netst ...
- 《Linux内核分析》 第六周
<Linux内核分析> 第6周 一.进程的描述 1.进程控制块PCB 2.linux下的进程转化图 TASK_RUNNING可以是就绪态或者执行态,具体取决于系统调用 TASK_ZOMBI ...
- 第二个Sprint冲刺第二天(燃尽图)
- Mysql设置允许外网访问(图文)
1.打开mysql.exe(MySQL Command Line Client),输入密码 2.输入:use mysql; 3.查询host输入: select user,host from user ...
- Oracle与SQLSERVER修改数据文件的路径
1. SQLSERVER ALTER DATABASE CWBASEMSS modify file (name = cwbasemss_dat ,filename = 'c:\cwdata\mss\C ...