UVa 10817 校长的烦恼

https://vjudge.net/problem/UVA-10817

题意:

某校有m个教师和n个求职者,需讲授s个课程,已知每人的工资c和能教的课程集合,要求支付最少的工资使得每门课都至少有两名老师能教。

思路:

s1表示恰好有一个人教的科目集合,s2表示至少有两个人教的科目集合。

d[i][s1][s2]表示已经考虑了前i个人时的最小花费。参考了大神的代码,如下:

 1 #include<iostream>
 2 #include<string>
 3 #include<cstring>
 4 #include<sstream>
 5 #include<algorithm>
 6 using namespace std;
 7
 8
 9 const int maxn = 120 + 10;
10 const int maxs = 8 + 1;
11 #define INF 100000000
12 int m, n, s;
13 int c[maxn], st[maxn];//数组c表示工资,st表示第i个老师教课的集合
14 int d[maxn][1 << maxs][1 << maxs];
15
16 int dp(int i, int s0, int s1, int s2)
17 {
18     if (i == m + n)
19         return s2 == (1 << s) - 1 ? 0 : INF;//如果s2恰好等于全部课程的集合时,已经满足题意,不需要花钱
20     int& ans = d[i][s1][s2];
21     if (ans >= 0)return ans;
22     ans = INF;
23     if (i >= m)  ans = dp(i + 1, s0, s1, s2);//不选第i个应聘者,由于选i应聘者会导致s0,s1,s2改变,因此先初始化成不选
24     int m0 = st[i] & s0;//只有第i个应聘者会教的课程
25     int m1 = st[i] & s1;//第i个应聘者也会教的课程
26     s0 ^= m0;//在s0集合中除去所有只有i应聘者会教的课程,即m0
27     s1 = (s1^m1) | m0;//m1代表的所有课程变为了至少两个人会教,从s1中除去,同时加上m0
28     s2 |= m1;//将m1添加到s2
29     ans = min(ans, c[i] + dp(i + 1, s0, s1, s2));//选第i个应聘者,取较小者
30     return ans;
31 }
32
33 int main()
34 {
35     //freopen("D:\\txt.txt", "r", stdin);
36     while (~scanf("%d%d%d", &s, &m, &n) && s&&m&&n)
37     {
38         memset(d, -1, sizeof(d));
39         memset(st, 0, sizeof(st));
40         getchar();
41         for (int i = 0; i < m + n; i++)
42         {
43             string str;
44             getline(cin, str);
45             stringstream ss(str);
46             int x, flag = 1;
47             while (ss >> x)
48             {
49                 if (flag){ flag = 0; c[i] = x; }
50                 else
51                 {
52                     x--;   //将科目从0开始编号
53                     st[i] |= (1 << x);  //二进制的压缩存储
54                 }
55             }
56         }
57         int ans = dp(0, (1 << s) - 1, 0, 0);
58         printf("%d\n", ans);
59     }
60     return 0;
61 }
时间: 2024-10-07 04:39:14

UVa 10817 校长的烦恼的相关文章

10817 - Headmaster&#39;s Headache(校长的烦恼)

经典的状态压缩DP . 根据DP的阶段定义,我们需要枚举每一个教师进行递推,但是由于每个教师可以教授的课程是复杂多样的,所以使得状态变得难以转移 .那么要怎么样表示状态呢? 显然增加一两个维度是无法胜任的,所以我们可以用二进制枚举子集的方法,用一个整数通过位运算充当一个集合 . C++提供的位运算符极像对集合的操作,我们恰好可以利用这一点 . 用d[i][s1][s2]表示考虑了前i个人时的最小花费 . 其中s1表示恰有一个人教的科目集合,s2表示至少有两个人教的科目集合 .因为由这两个量就可以

(状压dp)uva 10817 Headmaster&#39;s Headache

题目地址 1 #include <bits/stdc++.h> 2 typedef long long ll; 3 using namespace std; 4 const int MAX=1e5+5; 5 const int INF=1e9; 6 int s,m,n; 7 int cost[125]; 8 //char sta[MAX]; 9 string sta; 10 int able[125]; 11 int dp[125][1<<8][1<<8]; 12 in

UVA 10817 - Headmaster&#39;s Headache

题目:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=20&page=show_problem&problem=1758 状态压缩的DP,dp[i][st]表示状态为st考虑后面i个人所有人最小花费, 因为每个科目有三种状态,可以用一个三进制数表示, 状态不是很多,所以可以把预先把每个数的三进制预处理出来, 决策为选和不选. #include<bits/std

UVA 10817 Headmaster&#39;s Headache 状压DP

记录两个状态S1,S2分别记录哪些课程被1个人教过或2个人教过,然后记忆化搜索 UVA - 10817 Headmaster's Headache Time Limit: 3000MS   Memory Limit: Unknown   64bit IO Format: %lld & %llu Submit Status Description Problem D: Headmaster's Headache Time limit: 2 seconds The headmaster of Spr

UVA - 10817 Headmaster&#39;s Headache (状压dp+记忆化搜索)

题意:有M个已聘教师,N个候选老师,S个科目,已知每个老师的雇佣费和可教科目,已聘老师必须雇佣,要求每个科目至少两个老师教的情况下,最少的雇佣费用. 分析: 1.为让雇佣费尽可能少,雇佣的老师应教他所能教的所有科目. 2.已聘老师必须选,候选老师可选可不选. 3.dfs(cur, subject1, subject2)---求出在当前已选cur个老师,有一个老师教的科目状态为 subject1,有两个及以上老师教的科目状态为 subject2的情况下,最少的雇佣费用. dp[cur][subje

UVa 10817 (状压DP + 记忆化搜索) Headmaster&#39;s Headache

题意: 一共有s(s ≤ 8)门课程,有m个在职教师,n个求职教师. 每个教师有各自的工资要求,还有他能教授的课程,可以是一门或者多门. 要求在职教师不能辞退,问如何录用应聘者,才能使得每门课只少有两个老师教而且使得总工资最少. 分析: 因为s很小,所以可以用状态压缩. dp(i, s1, s2)表示考虑了前i个人,有一个人教的课程的集合为s1,至少有两个人教的集合为s2. 在递归的过程中,还有个参数s0,表示还没有人教的科目的集合. 其中m0, m1, s0, s1, s2的计算用到位运算,还

UVA 10817 十一 Headmaster&#39;s Headache

Headmaster's Headache Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu Submit Status Practice UVA 10817 1 #include <stdio.h> 2 #include <string.h> 3 #include <algorithm> 4 using namespace std; 5 const int inf=1e

Uva 10817 Headmaster&#39;s Headache (DP+ 状态压缩)

Problem D: Headmaster's Headache Time limit: 2 seconds The headmaster of Spring Field School is considering employing some new teachers for certain subjects. There are a number of teachers applying for the posts. Each teacher is able to teach one or

状压DP UVA 10817 Headmaster&#39;s Headache

题目传送门 1 /* 2 题意:学校有在任的老师和应聘的老师,选择一些应聘老师,使得每门科目至少两个老师教,问最少花费多少 3 状压DP:一看到数据那么小,肯定是状压了.这个状态不好想,dp[s1][s2]表示s1二进制表示下至少有1位老师的科目集合 4 s2表示至少有2位老师的科目集合所花费的最小金额,状态转移方程(01):dp[t1][t2]=min(dp[t1][t2],dp[j][k]+c[i]); 5 j,k为当前两个集合,t1,t2为转移后的集合,另外求t1,t2用到了& |位运算