BZOJ 1226 学校食堂(状压DP)
2024-08-25 20:36:31
状压DP
f(i,j,k)表示前i−1个人已经吃了饭,且在i之后的状态为j的人也吃了饭(用二进制表示后面的状态),最后吃的那个人是i之后的第k个
(注意k可以是负数)
然后
如果j&1=1那么就表明第i个人也是吃了的,所以可以转移到f(i+1,j>>1,k−1)
否则就枚举下一个吃饭的人,转移到f(i,j+1<<l,l)
这么看也不是很难吧哈。。
# include <cstdio>
# include <cstring>
# include <cstdlib>
# include <iostream>
# include <vector>
# include <queue>
# include <stack>
# include <map>
# include <set>
# include <cmath>
# include <algorithm>
using namespace std;
# define lowbit(x) ((x)&(-x))
# define pi acos(-1.0)
# define eps 1e-
# define MOD
# define INF
# define mem(a,b) memset(a,b,sizeof(a))
# define FOR(i,a,n) for(int i=a; i<=n; ++i)
# define FO(i,a,n) for(int i=a; i<n; ++i)
# define bug puts("H");
# define lch p<<,l,mid
# define rch p<<|,mid+,r
//# define mp make_pair
# define pb push_back
typedef pair<int,int> PII;
typedef vector<int> VI;
# pragma comment(linker, "/STACK:1024000000,1024000000")
typedef long long LL;
int Scan() {
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
void Out(int a) {
if(a<) {putchar('-'); a=-a;}
if(a>=) Out(a/);
putchar(a%+'');
}
const int N=;
//Code begin... struct Node{int t, b;}node[N];
int dp[N][<<][]; int main ()
{
int T, n;
scanf("%d",&T);
while (T--) {
scanf("%d",&n); FO(i,,N) FO(j,,<<) FO(k,,) dp[i][j][k]=INF;
FOR(i,,n) scanf("%d%d",&node[i].t,&node[i].b);
int mi=INF;
FOR(i,,n) {
--mi;
if (mi<) break;
mi=min(mi,node[i].b);
dp[][<<(i-)][(i-)+]=;
}
FOR(i,,n) FO(j,,<<) FOR(k,,) {
if (dp[i][j][k]==INF) continue;
if (j&) dp[i+][j>>][k-]=min(dp[i+][j>>][k-],dp[i][j][k]);
else {
mi=INF;
FOR(l,i,n) {
--mi;
if (mi<) break;
if ((j&(<<(l-i)))==) {
dp[i][j|(<<(l-i))][l-i+]=min(dp[i][j|(<<(l-i))][l-i+],dp[i][j][k]+(node[l].t^node[i+k-].t));
mi=min(mi,node[l].b);
}
}
}
}
int ans=INF;
FOR(i,,) ans=min(ans,dp[n+][][i]);
printf("%d\n",ans);
}
return ;
}
最新文章
- velocity的一些用法
- Troubleshooting FIM: (No Display Name) in FIM Portal
- [rm] Linux 防止";rm -rf /"; 误删除
- [转]反向代理过程与Nginx特点详解
- [转载]解决zabbix在configure时候遇到的问题(Ubuntu)
- Filter案例
- springboot mybatis优雅的添加多数据源
- 基于TCP协议的socket编程
- 执行发送邮件Send方法时,报错:邮箱不可用。 服务器响应为: 5.7.1 Unable to relay for xxx@xxx.com
- 在C#中使用ZBar识别条形码
- [Python]基础教程(2)、PyCharm安装及中文编码
- es修改指定的field(partial update)
- MTU 和 MSS 关系、 IP分片、TCP分段
- 通过U盘启动vmware虚拟机
- Linux 的基础命令的操作
- Camera 预览变形问题解决
- 初学Oracle
- Scrapy的安装--------Windows、linux、mac等操作平台
- SSIS 自测题-数据流控件类
- Qt Creator子目录项目-类似VS解决方案
热门文章
- day5 二值化
- [CTSC1997]选课
- Android线程管理(三)——Thread类的内部原理、休眠及唤醒
- React入门基础(学习笔记)
- 学习HTML 第四节.插入图像
- sql server 按月对数据表进行分区
- Tensorflow基本开发架构
- Towards Accurate Multi-person Pose Estimation in the Wild 论文阅读
- Python+MySQL开发医院网上预约系统(课程设计)一
- 【bzm-Random CSV Data Set Config】 -jmeter - 文件中随机取参的方法,(插件自带)