这道dp题 可谓是比较难了,我想了2h 总是觉得自己设的状态没有包涵全部的状态空间 一直想不出来状态 最后败北。

正解是这样的 我们肯定是有一维i的表示 到了i 这个人吃饭了 但是在i吃饭之前后面的7个人都是有可能吃饭的,所以得再加一维j 表示自己和后面7人的状态,由于代价是和上一个吃饭的人有关的 所以k表示上次吃饭的人,这还没转移就有点不太对了,k这个维度囊括过多的不必要状态 我们尝试修改这一维的状态 表示为i 距上一次吃饭的人的距离。 显然[-8 , 7].

仔细思考这样的状态 已经囊括了所有的状态空间,故可以开始状态转移了。

//#include<bits/stdc++.h>
#include<iomanip>
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<queue>
#include<deque>
#include<cmath>
#include<ctime>
#include<cstdlib>
#include<stack>
#include<algorithm>
#include<vector>
#include<cctype>
#include<utility>
#include<set>
#include<bitset>
#include<map>
#define INF 1000000000
#define ll long long
#define min(x,y) ((x)>(y)?(y):(x))
#define max(x,y) ((x)>(y)?(x):(y))
#define RI register ll
#define db double
#define EPS 1e-8
using namespace std;
char buf[<<],*fs,*ft;
inline char getc()
{
return (fs==ft&&(ft=(fs=buf)+fread(buf,,<<,stdin),fs==ft))?:*fs++;
}
inline int read()
{
int x=,f=;char ch=getc();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getc();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getc();}
return x*f;
}
//SDOI DP 求最小排队时间 其中代价为 (a|b)-(a&b)
//显然有状态 f[i][j][k]表示 到了第i个人且自己和后面7人是否吃饭的状态为j上一个吃饭的人距离i为k时的最小代价.
const int MAXN=;
int n,T,maxx;
int a[MAXN],b[MAXN];
int f[MAXN][<<][];
int main()
{
//freopen("1.in","r",stdin);
T=read();
while(T--)
{
n=read();
memset(f,,sizeof(f));
maxx=f[][][];
for(int i=;i<=n;++i)a[i]=read(),b[i]=read();
f[][][]=;//k的值域 [-8,7] 整体平移8
for(int i=;i<=n;++i)
{
for(int j=;j<(<<);++j)
{
for(int k=;k<=;++k)
{
if(f[i][j][k]==maxx)continue;
if(j&)f[i+][j>>][k-]=min(f[i+][j>>][k-],f[i][j][k]);
else
{
int limit=maxx;
for(int l=;l<=;++l)//枚举接下来谁吃饭
{
if(j&(<<l))continue;
if(i+l>limit)break;
limit=min(limit,i+l+b[i+l]);
f[i][j|(<<l)][l+]=min(f[i][j|(<<l)][l+],f[i][j][k]+((i+k-)?(a[i+k-]^a[i+l]):));
//cout<<f[i][j|(1<<l)][l+8]<<endl;
}
}
}
}
}
int ans=maxx;
for(int i=;i<=;++i)ans=min(ans,f[n+][][i]);
printf("%d\n",ans);
}
return ;
}

撒花~

最新文章

  1. 数据库日常维护-CheckList_01历史Agent Job执行情况检查
  2. Oracle备库TNS连接失败的分析
  3. xmpp整理笔记:用户网络连接及好友的管理
  4. VS2010/VS2013怎么复制项目/拷贝项目/克隆项目
  5. 如何设置div高度为100%
  6. iOS开发-Alcatraz插件管理
  7. JavaMail 发送邮件案例
  8. jQuery源码笔记——二
  9. TObject简要说明-对象的创建流程
  10. UVA 1291 Dance Dance Revolution(DP)
  11. sublime工具篇
  12. Maven搭建SSH框架
  13. Spring Boot tomcat
  14. antd-mobile Picker组件默认值
  15. 利用git将项目上传到github
  16. module object has no attribute dumps的解决方法
  17. python中的常用模块(2)
  18. 006-markdown基础语法
  19. ResourceNotFound: rosbridge_server
  20. (Oracle)DBMS_SYSTEM工具-01[20180510]

热门文章

  1. css自动省略号...,通过css实现单行、多行文本溢出显示省略号
  2. 关于ganymed-ssh2版本262和build210的SCPClient类的区别
  3. Buy a Ticket,题解
  4. [SpringBoot]SpringBoot中使用redis事务
  5. 仿Neo4j里的知识图谱,利用d3+vue开发的一个网络拓扑图
  6. 解决alert在ios版微信中显示url的问题(重写alert)
  7. CMDB03 /今日未采集的资产、资产入库、资产变更记录、资产采集
  8. python 装饰器(一):装饰器基础(一)装饰器形式,何时执行
  9. linux专题(五):常用的基本命令(三)文件内容查看
  10. EF实现简单的增删改查