状压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 ;
}

最新文章

  1. velocity的一些用法
  2. Troubleshooting FIM: (No Display Name) in FIM Portal
  3. [rm] Linux 防止&quot;rm -rf /&quot; 误删除
  4. [转]反向代理过程与Nginx特点详解
  5. [转载]解决zabbix在configure时候遇到的问题(Ubuntu)
  6. Filter案例
  7. springboot mybatis优雅的添加多数据源
  8. 基于TCP协议的socket编程
  9. 执行发送邮件Send方法时,报错:邮箱不可用。 服务器响应为: 5.7.1 Unable to relay for xxx@xxx.com
  10. 在C#中使用ZBar识别条形码
  11. [Python]基础教程(2)、PyCharm安装及中文编码
  12. es修改指定的field(partial update)
  13. MTU 和 MSS 关系、 IP分片、TCP分段
  14. 通过U盘启动vmware虚拟机
  15. Linux 的基础命令的操作
  16. Camera 预览变形问题解决
  17. 初学Oracle
  18. Scrapy的安装--------Windows、linux、mac等操作平台
  19. SSIS 自测题-数据流控件类
  20. Qt Creator子目录项目-类似VS解决方案

热门文章

  1. day5 二值化
  2. [CTSC1997]选课
  3. Android线程管理(三)——Thread类的内部原理、休眠及唤醒
  4. React入门基础(学习笔记)
  5. 学习HTML 第四节.插入图像
  6. sql server 按月对数据表进行分区
  7. Tensorflow基本开发架构
  8. Towards Accurate Multi-person Pose Estimation in the Wild 论文阅读
  9. Python+MySQL开发医院网上预约系统(课程设计)一
  10. 【bzm-Random CSV Data Set Config】 -jmeter - 文件中随机取参的方法,(插件自带)