4.1 题意描述
花花家的超市是 24 小时营业的,现在需要招聘收银员。
超市每个小时都需要不同数量的收银员,用 ai 表示一天中 i 点到 i + 1 点这一小时内需要
的收银员数量,特别地 a23 表示 23 点到次日 0 点需要的收银员数量。每个时刻可以有多于 ai
的收银员工作,但是绝对不能少于 ai 人。现有 n 人应聘,每个人愿意从一个特定的整点开始
连续工作 8 小时。花花想知道最少要招多少人。
若无解请输出 -1。
4.2 输入格式
输入第一行包括一个正整数 t,表示测试组数。
接下来 2t 行,每两行表示一个测试点:
其中第一行包括 24 个非负整数 ai(i 2 [0; 23]),表示至少需要 ai 个人从 i 点工作到 i + 1
点(特别地 a23 表示 23 点到次日 0 点)。
第二行包括 24 个非负整数 bi(i 2 [0; 23]),表示应聘的人中有 bi 个人愿意从 i 点工作到
i + 1 点(特别地 b23 表示 23 点到次日 0 点)。
4.3 输出格式
对于每个测试组,输出一行包含一个整数表示最少要招多少人或 -1。
4.4 样例输入
1
0 0 0 0 0 0 0 0 2 2 1 5 2 0 3 1 1 4 1 4 2 6 3 3
1 1 1 0 1 0 0 0 0 1 3 2 0 0 4 0 3 0 1 0 0 2 0 0
4.5 样例输出
12
4.6 样例解释
一种最优的招聘方案为:
0 0 1 0 1 0 0 0 0 0 2 2 0 0 0 0 3 0 1 0 0 2 0 0

4.7 数据规模与约定
• 对于 50% 的数据: n ≤ 20; t = 1;
• 另有 20% 的数据: n ≤ 100; t = 1;
• 另有 20% 的数据: n ≤ 500;
• 对于所有编号为奇数的数据: ai = 0; i 2 [0; 7];
• 对于 100% 的数据: n ≤ 1000; ∑bi = n; 0 ≤ ai ≤ n; t ≤ 10。

/*
查分约束系统,做过的题并不多,所以写起来很费事。我们很容易想到前缀和,前缀和中
①s[i-1]<=s[i]
②s[i-8]+a[i]<=s[i](i>8)
③s[i+16]+a[i]-s[24]<=s[i]
④s[i]-b[i]<=s[i-1]
求最长路
然而我们发现,③并不满足查分约束系统的形式,我们考虑到枚举s[24],使s[24]等于一个数,注意这里不能用二分,为什么?比正解大的数并不能保证他的成立,因为由过大的s[24]退出来的其他s是错误的,但如果s[24]恰巧是正解,就不会出现这个问题
*/
#include<iostream>
#include<cstdio>
#include<string>
#include<cstring>
#include<algorithm>
#include<queue>
#define ll long long
using namespace std;
const int maxn = ;
int read(){
char ch=getchar();
int x=,f=;
while(!(ch>=''&&ch<='')){if(ch=='-')f=-;ch=getchar();};
while(ch>=''&&ch<=''){x=x*+(ch-'');ch=getchar();};
return x*f;
}
struct edge{
int v;
int w;
int nxt;
}e[maxn*];
int T,a[maxn],b[maxn];
int vis[maxn],d[maxn],flag;
int head[maxn],cnt;
void ins(int u,int v,int w){
cnt++;
e[cnt].v = v;
e[cnt].w = w;
e[cnt].nxt = head[u];
head[u] = cnt;
}
bool spfa(int s){
flag++;
queue<int> q;
for(int i = ;i <= ;i++){
d[i] = -;
}
d[] = ;
q.push();
vis[] = flag;
int now,to;
while(!q.empty()){
now = q.front();
q.pop();
//cout<<now<<" "<<d[now]<<endl;
for(int i = head[now];i;i = e[i].nxt){
if(d[e[i].v] < d[now] + e[i].w){
d[e[i].v] = d[now] + e[i].w;
if(d[e[i].v] > s)return false;
if(vis[e[i].v] != flag){
vis[e[i].v] = flag;
q.push(e[i].v);
//cout<<now<<" "<<e[i].v<<" "<<d[now]<<" "<<e[i].w<<" "<<d[e[i].v]<<endl; }
}
}
vis[now] = ;
}
return true;
}
bool check(int s){
//cout<<s<<endl;
cnt = ;
for(int i = ;i <= ;i++){
head[i] = ;
}
for(int i = ;i <= ;i++) ins(i-,i,a[i]);
for(int i = ;i <= ;i++) ins(i+,i,a[i]-s);
for(int i = ;i <= ;i++) ins(i-,i,);
for(int i = ;i <= ;i++) ins(i,i-,-b[i]);
ins(,,s);
ins(,,-s);
return spfa(s);
}
void dvd(){
int l = ,r = ,mid,ans;
while(){
if(l > ){
cout<<-<<endl;
break;
}
if(check(l)){
cout<<l<<endl;
break;
}else{
l++;
}
}
}
int main(){
freopen("cashier.in","r",stdin);
freopen("cashier.out","w",stdout);
T = read();
while(T--){
for(int i = ;i <= ;i++) a[i] = read();
for(int i = ;i <= ;i++) b[i] = read();
dvd();
}
return ;
}

湖南附中模拟day1 收银员的更多相关文章

  1. 湖南附中模拟day1 瞭望塔

    /* 这个题要用到树的性质,一般比较难的图论题会往这方面靠拢,这样用很容易出错,应该先写暴力,然后再去一点点想正解 */ //暴力70分 #include<iostream> #inclu ...

  2. 湖南附中模拟day1 金坷垃

    题意描述"没有金坷垃,怎么种庄稼?"花花家有一块田,所有庄稼排成了 N 行 M 列.初始时,每棵庄稼都有一个自己的高度hi;j.花花每次可以使用 1mol 的金克拉使一棵庄稼的高度 ...

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

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

  4. Acwing 393. 雇佣收银员

    算法1: 差分约束 + 枚举 O(Tn2028) 由于牵扯到 \([i - 8 + 1, i]\) 这段区间的和的约束,所以用前缀和更好表达一些. 设 \(num[i]\)表示 \(i\) 时刻有多少 ...

  5. poj1275收银员——差分约束

    题目:http://poj.org/problem?id=1275 做的第一道差分约束题... 首先,根据题意得出一些不等关系(f为前缀和雇佣人数): 0 <= f[i] - f[i-1] &l ...

  6. python面向过程编程小程序- 模拟超市收银系统

    6.16自我总结 功能介绍 程序功能介绍: 商品信息再读取修改买卖均已xlsx格式 且生成购物记录也按/用户名/购买时间.xlsx格式生成 账号密码输入错误三次按照时间进行冻结 用户信息已json格式 ...

  7. 移动零售批发行业新的技术特色-智能PDA手持移动扫描打印销售开单收银仪!!

    提起便利店或者超市,大家的第一印象一定是前台那个笨重的POS机和站在POS机后的收银员.传统的零售店中,笨重的POS机随处可见. 变革前,零售盘点多烦忧 一个顾客要结账,就需要通过POS机.小票打印机 ...

  8. C++ 大作业 超市收银系统

    #include<iostream> #include<fstream> #include<string> #include<iomanip> #inc ...

  9. [Python设计模式] 第2章 商场收银软件——策略模式

    github地址: https://github.com/cheesezh/python_design_patterns 题目 设计一个控制台程序, 模拟商场收银软件,根据客户购买商品的单价和数量,计 ...

随机推荐

  1. shell命令xargs

    今天准备找出nginx非空的日志并压缩成一个文件 find . -name "meta.access.log.*" -type f -size +0k | tar -cjv -f ...

  2. Guava的异常工具类--Throwables

    Guava为我们提供了一个非常方便并且实用的异常处理工具类:Throwables类. 这个类的API可以参见:http://docs.guava-libraries.googlecode.com/gi ...

  3. 常用RSS订阅地址

    随着Google Reader关门大吉,转战鲜果网了,RSS订阅地址经过几次折腾,丢的没剩几个了,写个文章记录一下吧,随时补充. --PS-- ,微信.微博之类的是社交平台,不能很好的梳理知识,一直用 ...

  4. Linux爆新漏洞,长按回车键70秒即可获得root权限

    漏洞来源这个安全问题来源于Cryptsetup存在的一个漏洞(CVE-2016-4484).Cryptsetup是在Linux统一密钥设置(Linux Unified Key Setup, LUKS) ...

  5. 《JavaScript权威指南》学习笔记 第七天 DOM操作

    由衷的觉得,随着IT技术的广泛的运用,个人电脑以及智能手机的使用,信息的获取与传播更为简单.但是我们获取有用信息的难度相反是越来越大了,想要保持住自己的注意力越来越难了.除了吃饭睡觉,我的精力都在电脑 ...

  6. JavaScript中的变量及数据类型

    转自:http://blog.csdn.net/mygis2005/article/details/7375419 JavaScript是一种弱类型的语言,变量名.操作符和方法名都区分大小写. 1.变 ...

  7. BZOJ1004: [HNOI2008]Cards

    三维01背包算出在每一个置换下不变的染色方案数,Burnside引理计算答案. PS:数据太水所以只算恒等置换也是可以过的. #include<bits/stdc++.h> using n ...

  8. uC/OS-II全局变量定义

    /*************************************************************************************************** ...

  9. select()

    select(),确定一个或多个套接口的状态,本函数用于确定一个或多个套接口的状态,对每一个套接口,调用者可查询它的可读性.可写性及错误状态信息,用fd_set结构来表示一组等待检查的套接口,在调用返 ...

  10. 10月20日MySQL数据库作业解析

    设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的表(一)~表(四)所示,数据如表1-2的表 ...