转载请注明出处,谢谢 http://blog.csdn.net/ACM_cxlove?viewmode=contents by---cxlove
比较综合的题目。
有n个物品,有两辆车载重分别是c1,c2.问需要多少趟能把物品运完。
n比较小,只有10,而且需要把所有物品全部运完,便想到状态压缩来保存状态。
首先记录好所有的可行状态,对于状态state能一趟运完。
然后再利用01背包,dp[j],表示已运的状态为j,如果状态j与ok[i]不冲突,则可以从状态j运一趟变为j|ok[i]。
dp[j|ok[i]]=min(dp[j|ok[i]],dp[j]+1);
#include<iostream>
#include<iomanip>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cstdlib>
#include<cmath>
#include<map>
#include<stack>
#include<set>
#include<queue>
#include<string>
#include<vector>
#define eps 1e-6
#define LL long long
#define LD long double
#define pi acos(-1.0)
#define inf 1<<30
using namespace std;
int n,c1,c2,cnt,w[10];
int ok[1<<10]; //能一次装过去的可行状态
int dp[1<<10];
bool judge(int state){ //判断state状态的物品能否一次运走
int sum=0;
int f[105];
memset(f,0,sizeof(f));
f[0]=1;
for(int i=0;i<n;i++)
if((1<<i)&state){
sum+=w[i];
for(int j=c1;j>=w[i];j--) //01背包判断可行否
f[j]=max(f[j-w[i]],f[j]);
}
if(sum>c1+c2) //如果总重量超过了两个车之和
return false;
for(int i=0;i<=c1;i++) //如果i可放c1,另外 一部分可以放入c2,则可行
if(f[i]&&sum-i<=c2)
return true;
return false;
}
int main(){
int t,cas=0;
scanf("%d",&t);
while(t--){
scanf("%d%d%d",&n,&c1,&c2);
for(int i=0;i<n;i++)
scanf("%d",&w[i]);
cnt=0;
for(int i=0;i<(1<<n);i++){
dp[i]=inf;
if(judge(i))
ok[cnt++]=i;
}
dp[0]=0;
for(int i=0;i<cnt;i++)
for(int j=0;j<(1<<n);j++)
if(!(ok[i]&j)) //如果两个状态没有冲突
dp[j|ok[i]]=min(dp[j|ok[i]],dp[j]+1); //在j的基础上再加入状态ok[i]
printf("Scenario #%d:\n%d\n\n",++cas,dp[(1<<n)-1]);
}
return 0;
}
分享到:
相关推荐
西北工业大学POJ试题C++答案代码+课程设计
北大POJ1207-The 3n + 1 problem 解题报告+AC代码
POJ-2870 Light Up + DFS(1级DFS+1级DFS) + Python - 思维导图 链接:https://blog.csdn.net/xxdragon126/article/details/122095922?spm=1001.2014.3001.5501
1011,1012,1013,1014,1015,1017,1026,1028,1032,1035,1041,1046,1129 1149 1154 1165 1182 1185 1190 1191 1201 1251 1273 1275 1276 1286 1322 1338 1363 1364 1401 1456 1459 1564 1579 1637 1657 1658 ...
Poj 3342 这是一道树状dp题目,题意是这样的,一个公司,每个人有且仅有一个Boss,除了最大的Boss没有Boss(显然),现在要参加一个聚会,要求参加的人数最多,但是棘手的.......
1.把自己的污水排到河里V 2.把自己的污水送到右边> 3.把自己的污水送到左边
北大POJ初级-简单搜索 解题报告+AC代码
关于poj dp分类,我一直寻找dp的分类,终于找到了,也上传一下
北大POJ3411-Paid Roads【class】 解题报告+AC代码
背包之01背包、完全背包、多重背包详解 Dynamic+Programming 典型的动态规划,用递归下的记忆化搜索来实现 1088 POJ 动态规划加速原理之四边形不等式 基于连通性状态压缩的动态规划问题 对一些DP题目的小结 树型动态...
这是黑不来就的poj上的所有dp题目的大型分类 好使好用
这是一道很不错的题目,dp解决的经典例子,是学习dp,和练习的好题目。。。。
Dp状态设计与方程总结 1.不完全状态记录 青蛙过河问题 利用区间dp 2.背包类问题 <1> 0-1背包,经典问题 无限背包,经典问题 判定性背包问题 带附属关系的背包问题 <5> + -1背包问题 双背包求最优值 构造...
北大POJ3009-Curling 2.0【DFS+Vector+回溯+剪枝】 解题报告+AC代码
poj1085,记忆化DP+状态压缩求解
北大POJ3026-Borg Maze【BFS+Prim】 解题报告+AC代码
北大POJ1015-Jury Compromise【动态规划DP】 解题报告+AC代码
北大POJ初级-所有题目AC代码+解题报告
北大POJ1159-Palindrome 解题报告+AC代码