Headmaster's Headache
题意:
s门课程,现任老师有m个给出工资,和他们能教的课,现在有n个应聘的老师,给出费用和能教的课程标号,求使每门课都至少有两个老师教的最小花费
分析:
n个老师选或不选有背包的特征,n很小想到用状压,s1表示每门课至少有一个老师教的情况,s2表示每门课至少有2个老师教的情况
起始状态是现任老师形成,dp[(j|ca[i])][(ca[i]&j)|k]=min(dp[(j|ca[i])][(ca[i]&j)|k],dp[j][k]+cost[i]); ca[i]是i个应聘者能教课程的状态
#include <map>
#include <set>
#include <list>
#include <cmath>
#include <queue>
#include <stack>
#include <cstdio>
#include <vector>
#include <string>
#include <cctype>
#include <complex>
#include <cassert>
#include <utility>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
using namespace std;
typedef pair<int,int> PII;
typedef long long ll;
#define lson l,m,rt<<1
#define pi acos(-1.0)
#define rson m+1,r,rt<<11
#define All 1,N,1
#define read freopen("in.txt", "r", stdin)
const ll INFll = 0x3f3f3f3f3f3f3f3fLL;
const int INF= 0x3f3f3f3f;
const int mod = ;
int dp[<<][<<],s,m,n;
int ca[],cost[],total;
void solve(int s1,int s2){
int ts=(<<s)-;
memset(dp,0x3f,sizeof(dp));
dp[s1][s2]=total;
for(int i=m+;i<=n+m;++i)
for(int j=ts;j>=;--j)
for(int k=ts;k>=;--k)
{
if(dp[j][k]>=INF)continue;
dp[(j|ca[i])][(ca[i]&j)|k]=min(dp[(j|ca[i])][(ca[i]&j)|k],dp[j][k]+cost[i]);
}
printf("%d\n",dp[ts][ts]);
}
int main()
{
char str[];
int num[];
while(~scanf("%d%d%d",&s,&m,&n)){
if(s==&&m==&&n==)break;
total=;
int s1=,s2=;
memset(num,,sizeof(num));
for(int i=;i<=n+m;++i){
scanf("%d",&cost[i]);
gets(str);
ca[i]=;
for(int j=;j<strlen(str);++j){
if(isdigit(str[j])){
int tmp=str[j]-'';
ca[i]|=(<<(tmp-));
if(i<=m)
num[tmp-]++;
}
}
if(i<=m){
total+=cost[i];
s1|=ca[i];
}
}
for(int i=;i<s;++i)
if(num[i]>)
s2|=(<<i);
solve(s1,s2);
}
return ;
}
Headmaster's Headache的更多相关文章
- UVA 10817	十一 Headmaster's Headache
		Headmaster's Headache Time Limit:3000MS Memory Limit:0KB 64bit IO Format:%lld & %llu Sub ... 
- UVA 10817 Headmaster's Headache(DP +状态压缩)
		Headmaster's Headache he headmaster of Spring Field School is considering employing some new teacher ... 
- 状压DP UVA 10817 Headmaster's Headache
		题目传送门 /* 题意:学校有在任的老师和应聘的老师,选择一些应聘老师,使得每门科目至少两个老师教,问最少花费多少 状压DP:一看到数据那么小,肯定是状压了.这个状态不好想,dp[s1][s2]表示s ... 
- UVa 10817 (状压DP + 记忆化搜索) Headmaster's Headache
		题意: 一共有s(s ≤ 8)门课程,有m个在职教师,n个求职教师. 每个教师有各自的工资要求,还有他能教授的课程,可以是一门或者多门. 要求在职教师不能辞退,问如何录用应聘者,才能使得每门课只少有两 ... 
- UVa 10817 Headmaster's Headache (状压DP+记忆化搜索)
		题意:一共有s(s ≤ 8)门课程,有m个在职教师,n个求职教师.每个教师有各自的工资要求,还有他能教授的课程,可以是一门或者多门. 要求在职教师不能辞退,问如何录用应聘者,才能使得每门课只少有两个老 ... 
- uva 10817 - Headmaster's Headache ( 状态压缩dp)
		本文出自 http://blog.csdn.net/shuangde800 题目链接: 点击打开链接 题目大意 某校有n个教师和m个求职者,已知每人的工资和能教的课程集合,要求支付最少的工资使得每 ... 
- 【UVa】Headmaster's Headache(状压dp)
		http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ... 
- UVa 10817 - Headmaster's Headache(状压DP)
		链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ... 
- UVA - 10817 Headmaster's Headache (状压类背包dp+三进制编码)
		题目链接 题目大意:有S门课程,N名在职教师和M名求职者,每名在职教师或求职者都有自己能教的课程集合以及工资,要求花费尽量少的钱选择一些人,使得每门课程都有至少两人教.在职教师必须选. 可以把“每个课 ... 
随机推荐
- MyBatis,动态传入表名,字段名的解决办法
			转载:http://luoyu-ds.iteye.com/blog/1517607 今天做项目,遇到的问题就是需求修改数据表的记录,而且字段名都不是固定的,也就是说是需要通过参数传入的, 本来这也不是 ... 
- Tomcat就是个容器,一种软件
			1.tomcat就是一个容器而已,一个软件,运行在java虚拟机. 2.tomcat是一种能接收http协议的软件,java程序猿自己也可以写出http解析的服务器啊. 3.tomcat支持servl ... 
- iOS开发--多线程
			前面在<Bison眼中的iOS开发多线程是这样的(二)>一文中讲完了多线程的NSThread,不难发现这种方式的多线程实现起来非常的复杂,为了简化多线程的开发,iOS提供了GCD来实现多线 ... 
- 示例:Servlet显示当前系统时间(时间格式化)
			package com.mhb; import java.io.IOException; import java.io.PrintWriter; import java.text.SimpleDate ... 
- Nginx+Tomcat+Memcached负载均衡集群服务搭建
			操作系统:CentOS6.5 本文档主要讲解,如何在CentOS6.5下搭建Nginx+Tomcat+Memcached负载均衡集群服务器,Nginx负责负载均衡,Tomcat负责实际服务,Memc ... 
- gdb 基本命令
			backtrace(或bt) 查看各级函数调用及参数 finish 连续运行到当前函数返回为止,然后停下来等待命令 frame(或f) 帧编号 选择栈帧 info(或i) locals 查看当前栈帧局 ... 
- Ubuntu下的svn的安装
			安装SVN问题很多,现在目前遇到的问题是,安装时候找不到svn connector的连接器 导致不能够对SVN插件进行完整安装.但是可以单独安装该插件 http://community.pol ... 
- Java泛型     通配符?     extends与super
			Java 泛型 关键字说明 ? 通配符类型 <? extends T> 表示类型的上界,表示参数化类型的可能是T 或是 T的子类 <? super T> 表示类型下界(Java ... 
- 真正解决ASP.NET每一个页面首次访问超级慢的问题 (转载)
			原文:http://www.afuhao.com/article_articleId-219.shtml 摘要:ASP.NET页面首次打开很慢,但别的页面如果没有访问过,去访问也会慢.你也许认为它是在 ... 
- 转:MVC2表单验证失败后,直接返回View,已填写的内容就会清空,可以这样做;MVC2输出文本;MVC2输出PDF文件
			ViewData.ModelState.AddModelError("FormValidator", message); foreach (string field in Requ ... 
