我们一位一位地来做,每次判断这一位能否放0,而且要在满足前几位的情况下。用dp来判断

具体来说,设f[i][j]表示前i个划分成j个区间能否满足,那么我们会有转移trans[i][k+1],当区间[i,k]的和在某些位上不是1时trans[i][k+1]=1

这些位,就是正在做的这位和它之前确定下来的取0的位数

那么每次就看f[N+1][A...B]是否有值,就可以确定下来这位答案到底是放0还是1了

这样做的复杂度,是O(n^3logV)的,最后一个子任务过不去

发现最后一个子任务A=1,那我们就可以在dp时少记一维,令f[i]表示使前i个数满足的最小区间数,看最后f{N+1]能否<=B就可以了

(或者像我一样zz地写一个最短路)

有一个要注意的点,就是<<操作,如果超出范围,是要写成类似于1LL<<55这样的

  1. #include<bits/stdc++.h>
  2. #define pa pair<int,int>
  3. #define ll long long
  4. using namespace std;
  5. const int maxm=,maxn=;
  6.  
  7. inline ll rd(){
  8. ll x=;char c=getchar();int neg=;
  9. while(c<''||c>''){if(c=='-') neg=-;c=getchar();}
  10. while(c>=''&&c<='') x=x*+c-'',c=getchar();
  11. return x*neg;
  12. }
  13.  
  14. int N,M,A,B,dis[maxn];
  15. bool tmp[maxn][maxn];
  16. bool trans[maxn][maxn],f[maxn][maxn],flag[maxn];
  17. ll sum[maxn],num[maxn];
  18. priority_queue<pa,vector<pa>,greater<pa> > q;
  19.  
  20. inline bool dp(){
  21. memset(f,,sizeof(f));f[][]=;
  22. for(int i=;i<B;i++){
  23. for(int j=;j<=N;j++){if(!f[i][j]) continue;
  24. for(int k=j+;k<=N+;k++){
  25. if(!trans[j][k]) continue;
  26. f[i+][k]=;
  27. }
  28. }
  29. }bool can=;
  30. for(int i=A;i<=B;i++){
  31. can|=f[i][N+];
  32. }return can;
  33. }
  34. inline bool dijkstra(){
  35. memset(dis,,sizeof(dis));while(!q.empty()) q.pop();
  36. memset(flag,,sizeof(flag));
  37. dis[]=;q.push(make_pair(,));
  38. while(!q.empty()){
  39. int p=q.top().second;q.pop();if(flag[p]) continue;
  40. if(p==N+) break;
  41. for(int i=p+;i<=N+;i++){
  42. if(!trans[p][i]||dis[i]<=dis[p]+) continue;
  43. dis[i]=dis[p]+;q.push(make_pair(dis[i],i));
  44. }
  45. }return dis[N+]<=B;
  46. }
  47.  
  48. inline void solve(){
  49. ll ans=;int i,j,k;
  50. for(i=;i<=N;i++) sum[i]=sum[i-]+num[i];
  51. ll l=sum[N];while(l) M++,l>>=;
  52. memset(trans,,sizeof(trans));
  53. for(int t=M;t;t--){
  54. memcpy(tmp,trans,sizeof(tmp));
  55. for(int i=;i<=N;i++){
  56. for(int j=i;j<=N;j++){
  57. if((sum[j]-sum[i-])&(1LL<<(t-))) trans[i][j+]=;
  58. }
  59. }
  60. bool can=(A==)?dijkstra():dp();
  61. if(!can){
  62. ans|=1LL<<(t-);memcpy(trans,tmp,sizeof(tmp));
  63. }
  64. }
  65. printf("%lld\n",ans);
  66. }
  67.  
  68. int main(){
  69. int i,j,k;
  70. //freopen("1967.in","r",stdin);
  71. N=rd(),A=rd(),B=rd();
  72. for(i=;i<=N;i++) num[i]=rd();
  73. solve();
  74. return ;
  75. }

luogu3646 巴厘岛的雕塑 (dp)的更多相关文章

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

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

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

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

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

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

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

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

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

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

  6. bzoj4069【APIO2015】巴厘岛的雕塑

    4069: [Apio2015]巴厘岛的雕塑 Time Limit: 10 Sec  Memory Limit: 64 MB Submit: 192  Solved: 89 [Submit][Stat ...

  7. 巴厘岛的雕塑(sculptures)

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

  8. 巴厘岛的雕塑 BZOJ 4069

    巴厘岛的雕塑 题解: 题意是要求分组使每组的和按位取或的值最小 那么考虑贪心,尽量使高位为0 于是枚举位置,从最高位枚举 假设当前枚举到第l位. 令 f[i][j] 表示前 i 个数分成 j 组,满足 ...

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

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

随机推荐

  1. [清华集训2017]榕树之心[树dp]

    题意 题目链接 分析 首先解决 \(subtask3\) ,我们的策略就是进入子树,然后用其它子树来抵消,注意在子树内还可以抵消. 可以转化为此模型:有一个数列 \(a\) ,每次我们可以选定两个值 ...

  2. VS2017一步一步断点调试解决Dapper语句出现的Bug

    最近再做一个项目,出现一个小bug,bug虽小,但是却要命啊.下面我show下我解决问题的方法. View层代码: @model List<mhq.Blog.Model.Blog> < ...

  3. MVC_防止HttpPost重复提交

    重复提交的场景很常见,可能是当时服务器延迟的原因,如购物车物品叠加,重复提交多个订单.常见的解决方法是提交后把Button在客户端Js禁用,或是用Js禁止后退键等.在ASP.NET MVC 3 Web ...

  4. C_数据结构_循环实现求阶乘

    # include <stdio.h> int main(void) { int val; printf("请输入一个数字:"); printf("val = ...

  5. Educational Codeforces Round 49 (Rated for Div. 2)A到C题

    A题意 给你t表示有t组测试数据,每组数据给你一个含小写字母的字符串,每个字符必须变为它相邻的字符,问最后是否能变成回文串.a不能变成z,反过来也不行 分析 只需对对称位置判断差是否小于2且不等于1, ...

  6. 12.11 Daily Scrum

      Today's Task Tomorrow's Task 丁辛 实现和菜谱相关的餐厅列表. 实现和菜谱相关的餐厅列表.             邓亚梅             美化搜索框UI. 美 ...

  7. 2-Twentieth Scrum Meeting-20151220

    任务安排 成员 今日完成 明日任务 闫昊 请假(数据库)   唐彬 请假(数据库)   史烨轩  尝试使用downloadmanager对notification进行更新  尝试使用downloadm ...

  8. 数组与字符串三(Cocos2d-x 3.x _Array容器)

    "程序=数据结构+算法" 在面向对象的语言中,诸如数组.堆栈.队列等的结构都被封装成了特定的类,按照特定数据结构的算法设计起来,这就是容器类. Cocos2d-x中,能使用的容器类 ...

  9. 软件工程第二次程序的作业:Java计算器实验

    1.计算器实验报告 2.https://github.com/lollipopangel/test/tree/master 3.实验截图 7+8 清除 六.总结 通过本次实验让我对JFrame类.JP ...

  10. 四则运算法则在Java中的实现

    软件工程的课程已经上过有一段时间了,前段时间由于比较忙着考试,所以关于四则运算的代码一直没有实现.同时由于近来一段时间一直在自学java,因为C++虽然也是面向对象,而且可以开发很多软件或者程序,但是 ...