【POJ 1275】 Cashier Employment(差分约束系统的建立和求解)
【POJ 1275】 Cashier Employment(差分约束系统的建立和求解)
Time Limit: 1000MS | Memory Limit: 10000K | |
Total Submissions: 7569 | Accepted: 2856 |
Description
number of cashiers at different times of each day (for example, a few cashiers after midnight, and many in the afternoon) to provide good service to its customers, and he wants to hire the least number of cashiers for this job.
The manager has provided you with the least number of cashiers needed for every one-hour slot of the day. This data is given as R(0), R(1), ..., R(23): R(0) represents the least number of cashiers needed from midnight to 1:00 A.M., R(1) shows this number for
duration of 1:00 A.M. to 2:00 A.M., and so on. Note that these numbers are the same every day. There are N qualified applicants for this job. Each applicant i works non-stop once each 24 hours in a shift of exactly 8 hours starting from a specified hour, say
ti (0 <= ti <= 23), exactly from the start of the hour mentioned. That is, if the ith applicant is hired, he/she will work starting from ti o'clock sharp for 8 hours. Cashiers do not replace one another and work exactly as scheduled, and there are enough cash
registers and counters for those who are hired.
You are to write a program to read the R(i) 's for i=0..23 and ti 's for i=1..N that are all, non-negative integer numbers and compute the least number of cashiers needed to be employed to meet the mentioned constraints. Note that there can be more cashiers
than the least number needed for a specific slot.
Input
of applicants in another line (0 <= N <= 1000), after which come N lines each containing one ti (0 <= ti <= 23). There are no blank lines between test cases.
Output
If there is no solution for the test case, you should write No Solution for that case.
Sample Input
1
1 0 1 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1
5
0
23
22
1
10
Sample Output
1
Source
做到如今为止 做的最麻烦的一个差分约束……
麻烦不是麻烦在求解上。而是建图……而且绝大多数差分约束的难点。都是建图。。毕竟求解就是个裸最短路
这题题意是 一个商店要招聘员工 商店有一个客流表 表示0~23点每点须要的最少员工数
之后一个整数n 表示有n个应聘员工
后面n行 每行一个0~23的整数 表示第i个员工工作的起始时间 每一个员工工作8小时
题目分析完成 条件不多 所以这就是这题的难点……要挖掘非常多隐含条件
设t[i]为商店第i小时须要的员工数 r[i]表示第i小时来应聘的员工数 数组S[i]表示0~i小时总共应聘的员工数
第一个条件 0 <= S[i]-S[i-1] <= r[i]
第二个条件 S[i]-S[i-8] >= t[i] (i-1时i-8招聘的员工刚好下班 因此S[i]-S[i-8]即为第i小时招聘的所有员工)
第三个条件 S[24]-S[0] <= sum(因为要找最少的总招聘人数,所以这里出现了一个未知量,而这个问题就转化成了求最小sum)
把三个问题化成同号 再细化一下 就变成了
S[i-1]-S[i] <= 0
S[i]-S[i-1] <= r[i]
S[i-8]-S[i] <= -t[i](0 < i <= 8)
S[i+16]-S[i] <= sum-t[i](8 < i <= 24)
S[24]-S[0] <= sum
找到不等关系就好办一点了 对sum二分 每次更新与sum有关的边权 然后跑最短路 推断一下能不能跑出来(有无负环)
代码例如以下:
#include <iostream>
#include <cmath>
#include <vector>
#include <cstdlib>
#include <cstdio>
#include <cstring>
#include <queue>
#include <list>
#include <algorithm>
#include <map>
#include <set>
#define LL long long
#define Pr pair<int,int>
#define fread() freopen("in.in","r",stdin)
#define fwrite() freopen("out.out","w",stdout) using namespace std;
const int INF = 0x3f3f3f3f;
const int msz = 10000;
const double eps = 1e-8; struct Edge
{
int u,v,w;
}; Edge eg[233333];
int w[25],r[25];
int dis[25];
int tp; bool bellman()
{
memset(dis,INF,sizeof(dis));
dis[0] = 0; for(int i = 0; i <= 24; ++i)
for(int j = 0; j < tp; ++j)
if(dis[eg[j].v] > dis[eg[j].u]+eg[j].w)
dis[eg[j].v] = dis[eg[j].u]+eg[j].w; //判负环
for(int j = 0; j < tp; ++j)
if(dis[eg[j].v] > dis[eg[j].u]+eg[j].w)
return false; return true;
} void Add(int u,int v,int w)
{
eg[tp].u = u;
eg[tp].v = v;
eg[tp++].w = w;
} //重建与sum有关的边
void buildgraph(int sum)
{
tp = 64;
for(int i = 1; i < 9; ++i)
Add(i,i+16,sum-w[i]);
Add(24,0,-sum);
} int main()
{
int t,x,n,low,high; scanf("%d",&t);
while(t--)
{
tp = 0; high = 0;
for(int i = 1; i <= 24; ++i)
scanf("%d",&w[i]); memset(r,0,sizeof(r));
scanf("%d",&n);
high = n; while(n--)
{
scanf("%d",&x);
r[x+1]++;
} //边权不变的边(与sum无关的边)
for(int i = 1; i <= 24; ++i)
{
Add(i-1,i,r[i]);
Add(i,i-1,0);
if(i >= 9) Add(i,i-8,-w[i]);
} low = 0;
int ans = INF;
while(low <= high)
{
int mid = (low+high)>>1; buildgraph(mid);
if(bellman())
{
ans = mid;
high = mid-1;
}else low = mid+1;
} if(ans == INF) puts("No Solution");
else printf("%d\n",ans);
} return 0;
}
【POJ 1275】 Cashier Employment(差分约束系统的建立和求解)的更多相关文章
- poj 1275 Cashier Employment - 差分约束 - 二分答案
A supermarket in Tehran is open 24 hours a day every day and needs a number of cashiers to fit its n ...
- [HDU 1529]Cashier Employment(差分约束系统)
[HDU 1529]Cashier Employment(差分约束系统) 题面 有一个超市,在24小时对员工都有一定需求量,表示为\(r_i\),意思为在i这个时间至少要有i个员工,现在有n个员工来应 ...
- 图论(差分约束系统):POJ 1275 Cashier Employment
Cashier Employment Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 7651 Accepted: 288 ...
- POJ 1275 Cashier Employment 挺难的差分约束题
http://poj.org/problem?id=1275 题目大意: 一商店二十四小时营业,但每个时间段需求的雇员数不同(已知,设为R[i]),现有n个人申请这份工作,其可以从固定时间t连续工作八 ...
- POJ1275 Cashier Employment[差分约束系统 || 单纯形法]
Cashier Employment Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 7997 Accepted: 305 ...
- POJ 1275 Cashier Employment(差分约束)
http://poj.org/problem?id=1275 题意 : 一家24小时营业的超市,要雇出纳员,需要求出超市每天不同时段需要的出纳员数,午夜只需一小批,下午需要多些,希望雇最少的人,给出每 ...
- poj 1275 Cashier Employment
http://poj.org/problem?id=1275 #include <cstdio> #include <cstring> #include <algorit ...
- POJ 1275-Cashier Employment(差分约束系统)
题目地址:id=1275">POJ 1275 题意: 给出一个超市24小时各须要R[i]个雇员工作,有N个雇员能够雇佣.他们開始工作时间分别为A[i],求须要的最少的雇员人数. 思路: ...
- 【POJ1275】Cashier Employment 差分约束
[POJ1275]Cashier Employment 题意: 超市经历已经提供一天里每一小时需要出纳员的最少数量————R(0),R(1),...,R(23).R(0)表示从午夜到凌晨1:00所需要 ...
随机推荐
- IIS HTTP 错误 401.3的解决办法
目标网站添加新用户Everyone,选上需要的Everyone用户权限
- Less简介及安装
CSS的短板 作为前端学习者的我们 或多或少都要学些 CSS ,它作为前端开发的三大基石之一,时刻引领着 Web 的发展潮向. 而 CSS 作为一门标记性语言,可能 给初学者第一印象 就是简单易懂,毫 ...
- java_线程的同步机制
1.同步代码块: 使用synchronized包住可能会出现安全问题的代码 import static java.lang.Thread.sleep; class Test01{ public sta ...
- 指针函数(Pointer Function)和函数指针(Pointer to Function或Function Pointer)
一.指针函数 1.解释:指针函数很好理解:简单来说,就是一个返回指针的函数,本质是一个函数.如: int fun(int x,int y); //这是一个普通函数的声明,返回值是一个int类型, ...
- 零基础入门学习Python(35)--图形用户界面入门:EasyGui
知识点 EasyGui学习文档[超详细中文版] 1. 建议不要在IDLE上运行EasyGui EasyGui是运行在TKinter上并拥有自身的事件循环,而IDLE也是Tkinter写的一个应用程序并 ...
- ruby on rails 常见配置错误解决
error:in `require': cannot load such file -- sqlite3/sqlite3_native (LoadError) 先删除 Ruby下的D:\Ruby22- ...
- Linux下安装SVN,仓库创建,用户权限管理
Exported from Notepad++ Linux下安装SVN,仓库创建,用户权限管理 1.SVN安装 Ubuntu系统下安装:sudoapt-getinstallsubv ...
- NOI模拟(3.3)螺旋序列(出题人一定是月厨)
Description S也想寻求真正的智慧,然而由于“抑制力”的存在,她必须先解决一系列询问.有一个长度为n的序列a,一个长度为m序列b被称为螺旋序列当且仅当b1=bm且对于1<=i<= ...
- HDU-2817,同余定理+快速幂取模,水过~
A sequence of numbers Time Limit: 2000/1 ...
- 主席树初探--BZOJ3524: [Poi2014]Couriers
n<=500000个数,m<=500000个询问,每次问区间里出现次数>(R-L+1)的数字是谁,没有输出0. 写了带修改发现不会不带修改了.... 不带修改的话,n个点,每个点表示 ...