D - Doing Homework HDU - 1074 (状压dp)
题目链接:https://cn.vjudge.net/contest/68966#problem/D
具体思路:我们可以把每个情况都枚举出来,然后用递归的形式求出最终的情况.
比如说 我们要求 10101 的扣分最小值,我们可以把 10100和00101和10001这三种 情况加上 对应的课的时候的最小值,具体解释看代码
(再理解一下,对于这个公式tmp[i]=tmp[i^(1<<j)]+max(sum-d[j],0)
我们之前求的是总的花费的时间,然后如果一门课的截止时间小于这个总的时间花费,也就是说这是要被扣分的没我们是要懂这些被扣分的情况中选取一个扣分最小的情况选出来.(等于的时候也需要考虑,因为有可能相等的时候有的路的花费是不同的)
AC代码:
#include<bits/stdc++.h>
using namespace std;
# define ll long long
const int maxn = 50000+100;
# define inf 0x3f3f3f3f
const int mod = 1e9;
struct node
{
string str;
int st;
int con;
} q[maxn];
int dp[maxn],pre1[maxn],pre2[maxn];
vector<int>vis;
int main()
{
ios::sync_with_stdio(false);
int T;
cin>>T;
while(T--)
{
vis.clear();
memset(dp,inf,sizeof(dp));
memset(pre1,0,sizeof(pre1));
memset(pre2,0,sizeof(pre2));
int n;
cin>>n;
dp[0]=0;
for(int i=0; i<n; i++)
{
cin>>q[i].str>>q[i].st>>q[i].con;
}
int maxstate=(1<<n)-1;
for(int i=1; i<=maxstate; i++)
{
int sum=0;
int tmp;
for(int j=0; j<n; j++)
{
if((1<<j)&i)sum+=q[j].con;;//所需要的时间
}
for(int j=0; j<n; j++)
{
if((1<<j)&i)
{
tmp=dp[i^(1<<j)]+max(sum-q[j].st,0);//这个公式的具体含义,我们要求的是加上最后一门课的最优情况,所以我们可以把所有的时间都加上,然后在计算一下新加入的这门课的截止时间,最后求一下差就可以了
if(tmp<=dp[i])
{
dp[i]=tmp;
pre1[i]=j;
pre2[i]=((1<<j)^i);
}
}
}
}
cout<<dp[maxstate]<<endl;
for(int i=maxstate; i>=1; i=pre2[i])
{
// cout<<q[pre1[i]].str<<endl;
vis.push_back(pre1[i]);
}
int len=vis.size();
for(int i=len-1; i>=0; i--)
{
cout<<q[vis[i]].str<<endl;
}
}
return 0;
}
D - Doing Homework HDU - 1074 (状压dp)的更多相关文章
- Doing Homework HDU - 1074 (状压dp)
Ignatius has just come back school from the 30th ACM/ICPC. Now he has a lot of homework to do. Every ...
- Doing Homework(HDU 1074状压dp)
题意:给你n个要做的作业,它们的名字.期限.可完成所需天数(必须连续)在规定期限不能完成要扣分(每天一分)求做作业顺序使扣分最少. 分析:作业数量较少,用状态压缩,做到第i种作业花费的天数dp[i]. ...
- HDU 1074状压DP
Doing Homework Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)To ...
- hdu 1074 (状压dp)
题意: 给出几个学科的作业.每个作业剩余的时间.完成每个学科作业的时间.如果在剩余时间内不能完成相应作业 就要扣分 延迟一天扣一分 求最小扣分 解析: 把这些作业进行全排列 求出最小扣分即可 但A( ...
- HDU 4778 状压DP
一看就是状压,由于是类似博弈的游戏.游戏里的两人都是绝对聪明,那么先手的选择是能够确定最终局面的. 实际上是枚举最终局面情况,0代表是被Bob拿走的,1为Alice拿走的,当时Alice拿走且满足变换 ...
- HDU 3001 状压DP
有道状压题用了搜索被队友骂还能不能好好训练了,, hdu 3001 经典的状压dp 大概题意..有n个城市 m个道路 成了一个有向图.n<=10: 然后这个人想去旅行.有个超人开始可以把他扔到 ...
- hdu 2809(状压dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2809 思路:简单的状压dp,看代码会更明白. #include<iostream> #in ...
- hdu 2167(状压dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2167 思路:经典的状压dp题,前后,上下,对角8个位置不能取,状态压缩枚举即可所有情况,递推关系是为d ...
- Engineer Assignment HDU - 6006 状压dp
http://acm.split.hdu.edu.cn/showproblem.php?pid=6006 比赛的时候写了一个暴力,存暴力,过了,还46ms 那个暴力的思路是,预处理can[i][j]表 ...
随机推荐
- 字符串使用replaceAll()方法报异常
对字符串使用replaceAll()方法替换 * ? + / | 等字符的时候会报以下异常 Dangling meta character '*' near index 0 这主要是因为这些符号在正则 ...
- 2017/10 冲刺NOIP集训记录:暁の水平线に胜利を刻むのです!
前几次集训都没有记录每天的点滴……感觉缺失了很多反思的机会. 这次就从今天开始吧!不能懈怠,稳步前进! 2017/10/1 今天上午进行了集训的第一次考试…… 但是这次考试似乎是近几次我考得最渣的一次 ...
- 【刷题】洛谷 P1402 酒店之王
题目描述 XX酒店的老板想成为酒店之王,本着这种希望,第一步要将酒店变得人性化.由于很多来住店的旅客有自己喜好的房间色调.阳光等,也有自己所爱的菜,但是该酒店只有p间房间,一天只有固定的q道不同的菜. ...
- BZOJ 3524 Couriers | 主席树
BZOJ 3524 Couriers 题意 求一个区间内出现超过区间长度的一半的数,如果没有则输出0. 题解 我可能太菜了吧--这道题愣是没想出来-- 维护权值主席树,记录每个数都出现过多少次: 查询 ...
- USACO Section 1.5 Prime Palindromes 解题报告
题目 题目描述 题目就是给定一个区间[a,b]((5 <= a < b <= 100,000,000)),我们需要找到这个区间内所有既是回文串又是素数的数字. 输入样例 5 500 ...
- Backbone学习总结
Backbone中文学习文档:http://www.css88.com/doc/backbone/ 来到公司已经有一段时间了,到现在深深的感觉到自己的能力弱的像只周黑鸭,又干涩又黝黑,充满了麻(手麻脑 ...
- 2:spring中的@resource
@Resource 其实是spring里面的注解注入. @Resource(这个注解属于J2EE的),默认安照名称进行装配,名称可以通过name属性进行指定, 如果没有指定name属性,当注解写在字段 ...
- js正则取出一个字符串小括号中的内容
var aa="ldfjsldfj(dsfasjfj3124123)"; var result = aa.match(/\(([^)]*)\)/); // 此时result=[&q ...
- [postfix]转发邮件设置
http://stackoverflow.com/questions/22537523/postfix-recipient-bcc-maps-multiple-recipients-how-to ht ...
- lightoj 1205 数位dp
1205 - Palindromic Numbers PDF (English) Statistics Forum Time Limit: 2 second(s) Memory Limit: 3 ...