loj10174.APIO2007动物园
时间:2021-08-24
本文章向大家介绍loj10174.APIO2007动物园,主要包括loj10174.APIO2007动物园使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
群友胡策搬的题,感觉还挺有意思。
每个小朋友只能看到 \(5\) 个动物,这个数非常少,而且考虑到每个动物只有移走留下两种状态,小朋友是否高兴只和这五个位置有关,于是可以状压。
首先我们可以直接预处理出来每五个位置的状态可以让多少小朋友满意,记为 \(s_{i,s}\),然后设 \(dp_{i,s}\) 表示当前到第 \(i\) 位,最后 \(5\) 位的状态是 \(s\) 的最优方案,那么有显然的转移 \(dp_{i,s}=\max(dp_{i-1,s\&15<<1},dp_{i-1,s\&15<<1|1})+g_{i,s}\)。
注意到这是一个环,前后的不好处理,于是我们直接钦定最后四位的取值,然后对每种都做一遍 dp 就好了。
#include<iostream>
#include<cstdio>
using namespace std;
int n,m,g[10001][1<<5],dp[100001][1<<5],ans;
inline int read()
{
int x=0;
char c=getchar();
while(c<'0'||c>'9')
c=getchar();
while(c>='0'&&c<='9')
{
x=(x<<1)+(x<<3)+(c^48);
c=getchar();
}
return x;
}
int main()
{
n=read(),m=read();
for(register int i=1;i<=m;++i)
{
int p=read(),f=read(),l=read(),x=0,y=0;
for(register int j=1;j<=f;++j)
x|=1<<((read()+n-p)%n);
for(register int j=1;j<=l;++j)
y|=1<<((read()+n-p)%n);
for(register int s=0;s<1<<5;++s)
if((s&x)||((s^31)&y))
++g[p][s];
}
for(register int i=0;i<1<<5;++i)
dp[0][i]=-0x3f3f3f3f;
for(register int i=0;i<1<<4;++i)
{
dp[0][i<<1]=0;
for(register int j=1;j<=n;++j)
for(register int s=0;s<1<<5;++s)
dp[j][s]=max(dp[j-1][(s&15)<<1],dp[j-1][(s&15)<<1|1])+g[j][s];
dp[0][i<<1]=-0x3f3f3f3f;
ans=max(ans,max(dp[n][i<<1],dp[n][i<<1|1]));
}
printf("%d\n",ans);
return 0;
}
原文地址:https://www.cnblogs.com/Forza-Ferrari/p/15181769.html
- Spring Boot中使用Flyway来管理数据库版本
- 缓存穿透、缓存并发、热点缓存之最佳招式
- 【译】Spring 官方教程:使用 Restdocs 创建 API 文档
- c#中设置快捷键
- 程序员你为什么这么累【续】:编码习惯之工具类规范
- IntelliJ IDEA 复杂的重构技巧
- 打造属于自己的支持版本迭代的Asp.Net Web Api Route
- 分布式消息队列 RocketMQ 源码分析 —— Message 拉取与消费(上)
- 分布式消息队列 RocketMQ 源码分析 —— Message 拉取与消费(下)
- Spring Boot中使用RabbitMQ
- Spring Cloud构建微服务架构:消息驱动的微服务(入门)【Dalston版】
- 哪类人适合当产品经理?
- 产品经理·杂谈
- Python机器学习中的特征选择
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Android 添加系统服务的方法详解
- android实现录屏小功能
- Android控件CardView实现卡片效果
- 非常好看的android音量旋钮
- Android实现按钮拖拽还原功能
- 百度地图实现小车规划路线后平滑移动功能
- frp内网穿透部署搭建教程,内网端口暴露给了外网
- Android使用Intent的Action和Data属性实现点击按钮跳转到拨打电话和发送短信界面
- Linux安装Collabora Online让NextCloud支持Office在线编辑
- 教你在CentOS7安装Vuze(Azureus)
- Pwn-EXP模板
- Linux学习随手记
- PHP session用法其实很简单
- 爬虫代理适合的业务和场景
- Flutter基础widgets教程-OverflowBox篇