当前位置: 首页 > news >正文

[APIO2015]巴厘岛的雕塑

刚开始看错题,以为是每一组或起来,求和的最小值,然后就瞎写了个dp,状态根本无法转移竟然过了六个点也是醉了

这个题根据数据可以分成两部分,可以按位贪心检验

对于n<=100的数据每一位直接n^3的dp就可以了

然后对于n>100的数据,A相当于没有限制,对每一位可以直接搞, g[i]代表到第i个雕塑至少分多少组才能符合要求

 1 #define MAXN 2010UL
 2 #include <cstdio>
 3 #include <cstring>
 4 
 5 using namespace std;
 6 
 7 typedef long long ll;
 8 
 9 int lg, n, B, A, f[110][110], g[MAXN];
10 ll ans, sum[MAXN];
11 
12 void Solve1() {
13     ll st = 0;
14     for(int l = lg ; l >= 0 ; -- l) {
15         memset(f, false, sizeof(f));
16         f[0][0] = true;
17         for(int k = 1 ; k <= B ; ++ k) {
18             for(int i = k ; i <= n ; ++ i) {
19                 for(int j = k-1 ; j < i ; ++ j) {
20                     if(f[k-1][j]&&(((sum[i]-sum[j])&(st|(1ll<<l)))==0)) {
21                         f[k][i] = true;
22                         break;
23                     }
24                 }
25             }
26         }
27         bool fg = false;
28         for(int i = A ; i <= B ; ++ i) if(f[i][n]) fg = true;
29         if(!fg) ans |= 1ll<<l;
30         else st |= 1ll<<l;
31     }
32     return;
33 }
34 
35 int MIN(int A, int B) { return A<B?A:B; }
36 
37 void Solve2() {
38     ll st = 0;
39     for(int l = lg ; l >= 0 ; -- l) {
40         memset(g, 0x3f, sizeof(g));
41         g[0] = 0;
42         for(int i = 1 ; i <= n ; ++ i) {
43             for(int j = 0 ; j < i ; ++ j) {
44                 if(((sum[i]-sum[j])&(st|(1ll<<l)))==0) g[i] = MIN(g[i], g[j]+1);
45             }
46         }
47         bool fg = (g[n]<=B);
48         if(!fg) ans |= 1ll<<l;
49         else st |= 1ll<<l;
50     }
51     return;
52 }
53 
54 int main() {
55     freopen("sculpture.in", "r", stdin);
56     freopen("sculpture.out", "w", stdout);
57     scanf("%d%d%d", &n, &A, &B);
58     for(int i = 1 ; i <= n ; ++ i) scanf("%lld", &sum[i]), sum[i] += sum[i-1];
59     lg = 0;
60     while((1ll<<lg)<=sum[n]) ++ lg;
61     if(A>1) Solve1();
62     else Solve2();
63     printf("%lld", ans);
64     return 0;
65 }
View Code

 

转载于:https://www.cnblogs.com/assassain/p/5440312.html

相关文章:

  • HTTP原理
  • javascript中利用柯里化函数实现bind方法
  • theano和keras使用过程中遇到的一些问题记录
  • 20145228《Java程序设计》第九周学习总结
  • Atitit.redis操作总结
  • Java数组技巧攻略
  • Java编程思想读书笔记之内部类
  • 2、变量var关键字
  • 基于CkEditor实现.net在线开发之路(5)列表页面开发
  • 大致相同功能和代码是分开两个源代码,还是保持一个代码
  • Java--------------Windows下Redis的安装使用
  • onethink对二维数组结果集进行排序
  • 地图处理之基本使用汇总
  • 函数指针和回调函数
  • java 程序的格式
  • IE9 : DOM Exception: INVALID_CHARACTER_ERR (5)
  • -------------------- 第二讲-------- 第一节------在此给出链表的基本操作
  • export和import的用法总结
  • IDEA常用插件整理
  • iOS | NSProxy
  • Java 23种设计模式 之单例模式 7种实现方式
  • Java 实战开发之spring、logback配置及chrome开发神器(六)
  • ReactNative开发常用的三方模块
  • socket.io+express实现聊天室的思考(三)
  • 工作踩坑系列——https访问遇到“已阻止载入混合活动内容”
  • 和 || 运算
  • ​Linux Ubuntu环境下使用docker构建spark运行环境(超级详细)
  • ​RecSys 2022 | 面向人岗匹配的双向选择偏好建模
  • #Js篇:单线程模式同步任务异步任务任务队列事件循环setTimeout() setInterval()
  • #ubuntu# #git# repository git config --global --add safe.directory
  • (32位汇编 五)mov/add/sub/and/or/xor/not
  • (草履虫都可以看懂的)PyQt子窗口向主窗口传递参数,主窗口接收子窗口信号、参数。
  • (多级缓存)缓存同步
  • (附源码)ssm高校运动会管理系统 毕业设计 020419
  • (强烈推荐)移动端音视频从零到上手(上)
  • (太强大了) - Linux 性能监控、测试、优化工具
  • (转) RFS+AutoItLibrary测试web对话框
  • .net core 6 使用注解自动注入实例,无需构造注入 autowrite4net
  • .NET Remoting Basic(10)-创建不同宿主的客户端与服务器端
  • .NET 指南:抽象化实现的基类
  • .Net转Java自学之路—基础巩固篇十三(集合)
  • .project文件
  • .w文件怎么转成html文件,使用pandoc进行Word与Markdown文件转化
  • @Autowired和@Resource的区别
  • [ vulhub漏洞复现篇 ] Hadoop-yarn-RPC 未授权访问漏洞复现
  • []利用定点式具实现:文件读取,完成不同进制之间的
  • [C#][opencvsharp]opencvsharp sift和surf特征点匹配
  • [C#]OpenCvSharp使用帧差法或者三帧差法检测移动物体
  • [C++]——带你学习类和对象
  • [CDOJ 1343] 卿学姐失恋了
  • [HackMyVM]靶场Crossbow
  • [IOI2018] werewolf 狼人
  • [java]删除数组中的某一个元素
  • [one_demo_9]判断数组是否递增
  • [PHP] 面向对象