题意:

      超市在每个时间都有需要的人数(24小时)比如 1 0 0 0 0 。。。。也就是说在第0个小时的时候要用一个人,其他的时间都不用人,在给你一些人工作的起始时间,如果雇佣了这个人,那么这个人就会从自己的其实时间工作8个小时后离开,给你需求和可雇佣的员工,问你满足需求超时最少雇佣多少人。

思路:

      经典的差分约束,之前尝试过很多次都没AC,今天终于AC了,现在我们就来找各种隐含条件。

设:

num[i] 表示第i个小时开始的有多少个人。

r[i] 表示第i个小时最少雇佣多少人。

s[i] 表示1。。。i小时开始工作的有多少人。 (我们以S为核心建图)

限制条件:

第i个小时雇佣并开始工作的人数 >= 0 

则 s[i] - s[i-1] >= 0

第i个小时雇佣并开始工作的人数 <= num[i] 

则 s[i] - s[i-1] <= num[i] 转化成 s[i-1] - s[i] >= -num[i]

第i个小时雇佣的人数 >= r[i]

则 s[i] - s[i-8] >= r[i]               (i >= 8 && i <= 24)

   s[24] + s[i] - s[i + 16] >= r[i]    (i <= 7)

观察最后一个不等式,出现了三个变量,不符合差分约束形式,所以我们就直接二分枚举

s[24]的值,也就是二分枚举雇佣人数的值,这样就把最后一个转换成

s[i] - s[i + 16] >= r[i] - mid

最后别忘了还有一个限制条件就是s[24] - s[0] = mid,=怎么建边呢?我们可以这样

s[24] - s[0] >= mid并且 s[24] - s[0] <= mid

第二个转换成 s[0] - s[24] >= -mid;

这样就可以二分下去了。。。


#include<stdio.h>
#include<string.h>
#include<queue> #define N_node 30
#define N_edge 10000
#define INF 1000000000

using namespace
std; typedef struct
{
int
to ,cost ,next;
}
STAR; STAR E[N_edge];
int
list[N_node] ,tot;
int
s_x[N_node];
int
r[30] ,num[1100]; void add(int a ,int b ,int c)
{

E[++tot].to = b;
E[tot].cost = c;
E[tot].next = list[a];
list[a] = tot;
} bool
Spfa(int s ,int n)
{
for(int
i = 0 ;i <= n ;i ++)
s_x[i] = -INF;
int
mark[N_node] = {0};
int
in[N_node] = {0};
s_x[s] = 0;
mark[s] = in[s] = 1;
queue<int>q;
q.push(s);
while(!
q.empty())
{
int
xin ,tou;
tou = q.front();
q.pop();
mark[tou] = 0;
for(int
k = list[tou] ;k ;k = E[k].next)
{

xin = E[k].to;
if(
s_x[xin] < s_x[tou] + E[k].cost)
{

s_x[xin] = s_x[tou] + E[k].cost;
if(!
mark[xin])
{

mark[xin] = 1;
if(++
in[xin] > n) return 0;
q.push(xin);
}
}
}
}
return
1;
} bool
ok(int mid)
{

memset(list ,0 ,sizeof(list));
tot = 1;
for(int
i = 1 ;i <= 24 ;i ++)
{

add(i - 1 ,i ,0);
add(i ,i - 1 ,-num[i]);
if(
i >= 8) add(i - 8 ,i ,r[i]);
else
add(i + 16 ,i ,r[i] - mid);
}

add(0 ,24 ,mid);
add(24 ,0 ,-mid);
return
Spfa(0 ,24);
} int main ()
{
int
t ,i ,a ,n;
scanf("%d" ,&t);
while(
t--)
{
for(
i = 1 ;i <= 24 ;i ++)
scanf("%d" ,&r[i]);
scanf("%d" ,&n);
memset(num ,0 ,sizeof(num));
for(
i = 1 ;i <= n ;i ++)
{

scanf("%d" ,&a);
num[a+1] ++;
}
int
low ,mid ,up;
low = 0 ,up = n;
int
ans = -1;
while(
low <= up)
{

mid = (low + up) >> 1;
if(
ok(mid))
{

ans = mid;
up = mid - 1;
}
else
low = mid + 1;
}
if(
ans == -1) puts("No Solution");
else
printf("%d\n" ,ans);
}
return
0;
}


hdu1529 差分约束(好题)的更多相关文章

  1. POJ 1364 King --差分约束第一题

    题意:求给定的一组不等式是否有解,不等式要么是:SUM(Xi) (a<=i<=b) > k (1) 要么是 SUM(Xi) (a<=i<=b) < k (2) 分析 ...

  2. poj 3159(差分约束经典题)

    题目链接:http://poj.org/problem?id=3159思路:题目意思很简单,都与给定的条件dist[b]-dist[a]<=c,求dist[n]-dist[1]的最大值,显然这是 ...

  3. poj 1201 Intervals——差分约束裸题

    题目:http://poj.org/problem?id=1201 差分约束裸套路:前缀和 本题可以不把源点向每个点连一条0的边,可以直接把0点作为源点.这样会快许多! 可能是因为 i-1 向 i 都 ...

  4. 【NOIP模拟赛】收银员(一道差分约束好题)

    /* s[]表示最优方案的序列中的前缀和,那么s[23]就是最优方案 由题意我们可以列出这样一些式子: s[i]+s[23]-s[16+i]>=a[i] (i-8<0) s[i]-s[i- ...

  5. hdu 3440(差分约束好题)

    House Man Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total S ...

  6. poj 3169 Layout 差分约束模板题

    Layout Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6415   Accepted: 3098 Descriptio ...

  7. BZOJ3436: 小K的农场(差分约束裸题&DFS优化判环)

    3436: 小K的农场 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2111  Solved: 986[Submit][Status][Discus ...

  8. hdu 1531(差分约束)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1531 差分约束的题之前也碰到过,刚好最近正在进行图论专题的训练,就拿来做一做. ①:对于差分不等式,a ...

  9. 【BZOJ3436】小K的农场(差分约束)

    [BZOJ3436]小K的农场(差分约束) 题面 由于BZOJ巨慢无比,使用洛谷美滋滋 题解 傻逼差分约束题, 您要是不知道什么是差分约束 您就可以按下\(Ctrl+W\)了 #include< ...

随机推荐

  1. Hi3559AV100-自己编译了u-boot、kernel及rootfs后,出现烧写错误或者烧写后板载无法启动的解决思路

    这篇随笔主要给出了Hi3559AV100-自己编译了u-boot.kernel及rootfs后,出现烧写错误或者烧写后板载无法启动的解决思路. 问题 (1)对于 u-boot 为官方的,kernel ...

  2. 【Arduino学习笔记01】关于Arduino引脚的一些笔记

    参考链接:https://www.yiboard.com/thread-831-1-1.html Arduino Uno R3 - 引脚图 Arduino Uno R3 - 详细参数 Arduino ...

  3. 关于PHP的表单提交显示

      实现功能:html页面,向表单内填入账号.密码:php页面,将填写的账号与密码信息展示出来. demo6.html代码如下: 1 <!DOCTYPE html> 2 <html& ...

  4. 华为OD机试题

    """最长回文字符串问题"""# 说明:方法很多,这个是最简单,也是最容易理解的一个,利用了动态规化.# 先确定回文串的右边界i,然后以右边 ...

  5. WPF 基础 - ControlTemplate

    常用 ControlTemplate 的地方:Control 的 Template 属性 运用效果举例:穿着 CheckBox 外衣的 ToggleButton,披着温度计的 ProgressBar. ...

  6. 《数据持久化与鸿蒙的分布式数据管理能力》直播课答疑和PPT分享

    问:hi3861开发板支持分布式数据库吗? 目前,分布式数据库仅支持Java接口,因此Hi3861没有现成的API用于操作分布式数据库. 问:分布式数据管理包括搜索吗? 分布式数据管理包括融合搜索能力 ...

  7. 攻防世界 reverse 进阶 12 ReverseMe-120

    程序流程很清晰 1 int __cdecl main(int argc, const char **argv, const char **envp) 2 { 3 unsigned int v3; // ...

  8. 利用浏览器favicon的缓存机制(F-Cache)生成客户端浏览器唯一指纹

    利用浏览器favicon的缓存机制(F-Cache)生成客户端浏览器唯一指纹 首先介绍下: 这个技术出自 UIC论文:https://www.cs.uic.edu/~polakis/papers/so ...

  9. teprunner测试平台Django引入pytest完整源码

    本文开发内容 pytest登场!本文将在Django中引入pytest,原理是先执行tep startproject命令创建pytest项目文件,然后从数据库中拉取代码写入文件,最后调用pytest命 ...

  10. Http请求状态码302,已得到html页面但未跳转?HttpServletRequest转发/HttpServletResponse重定向后,前端页面未跳转?Ajax怎么处理页面跳转?

    论断 出现此类错误,服务器端出现问题的可能性不大,大概率是前端问题. 问题概述 事情是这样的,我在用Java开发后端.前端页面使用jQuery库的 $.getJSON() 方法发送了一个Ajax请求. ...