【题目链接】:http://codeforces.com/problemset/problem/589/G

【题意】



有n个人;

每个人每天在开始工作之前,都需要di单位的准备时间,然后才能开始工作;

然后每个人都有m天的时间,每天有ti个单位的时间供每个人进行准备工作以及工作;

也就是说第i个人每天必须要先扣掉di个单位的时间;剩下的才是它能够工作的时间;

然后每个人都需要完成ri个单位的时间的工作量;

然后如果你发现某一天连准备的时间都不够的话,你可以跳过这一天;

问你最早在第几天,第i个人才能够完成ri个单位的时间的工作量;

【题解】



首先把m天的时间按照时间的多少降序排;

然后把n个人,按照ri的大小降序排;

然后顺序枚举n个人;

对于每个人,维护一个指针r,这里1..r对应了哪些天是>=d[i]的;

每次r递增一个,就把它加到树状数组里面,即对应的第id天递增t[i]个单位的时间,同时记录第id天之前有多少天是满足>=d[i]的;

然后二分第i天;

看看

前i天的时间和−前i天>=d[i]天的天数∗d[i]是不是大于等于r[i];

大于等于的话就变小一点,否则变大一点;



【Number Of WA】



0

(C++11不能编译,很奇怪)



【反思】



数据结构题的话,认真想想就好.

不要着急,想好了再动手。



【完整代码】

#include <bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define ms(x,y) memset(x,y,sizeof x)
#define Open() freopen("F:\\rush.txt","r",stdin)
#define Close() ios::sync_with_stdio(0) typedef pair<int,int> pii;
typedef pair<LL,LL> pll; const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
const double pi = acos(-1.0);
const int M = 2e5; struct abc{
int t,id;
}; struct person{
int d,r,id;
}; struct BIT{
pll a[M+10]; int lowbit(int x){
return x&(-x);
} void add(int x,int y){
while (x <= M){
a[x].fi+=y;
a[x].se+=1;
x+=lowbit(x);
}
} LL sum1(int x){
LL temp = 0;
while (x > 0){
temp += a[x].fi;
x-=lowbit(x);
}
return temp;
} LL sum2(int x){
LL temp = 0;
while (x > 0){
temp += a[x].se;
x-=lowbit(x);
}
return temp;
}
}; int n,m,b[M+10];
abc a[M+10];
person c[M+10];
BIT d; int main(){
//Open();
Close();
cin >> n >> m;
rep1(i,1,m){
cin >> a[i].t;
a[i].id = i;
}
sort(a+1,a+1+m,[&] (abc a,abc b){ return a.t > b.t;});
rep1(i,1,n){
cin >> c[i].d >> c[i].r;
c[i].id = i;
}
sort(c+1,c+1+n,[&] (person a,person b) {return a.d > b.d;});
int cur = 1;
rep1(i,1,n){
while (cur<=m && a[cur].t>=c[i].d){
d.add(a[cur].id,a[cur].t);
cur++;
}
int l = 0,r = m,temp = 0;
while (l <= r){
int mid = (l+r)>>1;
LL temp1 = d.sum1(mid),temp2 = d.sum2(mid);
temp1-=temp2*c[i].d;
if (temp1 >= c[i].r){
temp = mid;
r = mid - 1;
}else {
l = mid + 1;
}
}
b[c[i].id] = temp;
}
rep1(i,1,n) cout << b[i] <<' ';
return 0;
}

【codeforces 589G】Hiring的更多相关文章

  1. 【codeforces 415D】Mashmokh and ACM(普通dp)

    [codeforces 415D]Mashmokh and ACM 题意:美丽数列定义:对于数列中的每一个i都满足:arr[i+1]%arr[i]==0 输入n,k(1<=n,k<=200 ...

  2. 【codeforces 707E】Garlands

    [题目链接]:http://codeforces.com/contest/707/problem/E [题意] 给你一个n*m的方阵; 里面有k个联通块; 这k个联通块,每个连通块里面都是灯; 给你q ...

  3. 【codeforces 707C】Pythagorean Triples

    [题目链接]:http://codeforces.com/contest/707/problem/C [题意] 给你一个数字n; 问你这个数字是不是某个三角形的一条边; 如果是让你输出另外两条边的大小 ...

  4. 【codeforces 709D】Recover the String

    [题目链接]:http://codeforces.com/problemset/problem/709/D [题意] 给你一个序列; 给出01子列和10子列和00子列以及11子列的个数; 然后让你输出 ...

  5. 【codeforces 709B】Checkpoints

    [题目链接]:http://codeforces.com/contest/709/problem/B [题意] 让你从起点开始走过n-1个点(至少n-1个) 问你最少走多远; [题解] 肯定不多走啊; ...

  6. 【codeforces 709C】Letters Cyclic Shift

    [题目链接]:http://codeforces.com/contest/709/problem/C [题意] 让你改变一个字符串的子集(连续的一段); ->这一段的每个字符的字母都变成之前的一 ...

  7. 【Codeforces 429D】 Tricky Function

    [题目链接] http://codeforces.com/problemset/problem/429/D [算法] 令Si = A1 + A2 + ... + Ai(A的前缀和) 则g(i,j) = ...

  8. 【Codeforces 670C】 Cinema

    [题目链接] http://codeforces.com/contest/670/problem/C [算法] 离散化 [代码] #include<bits/stdc++.h> using ...

  9. 【codeforces 515D】Drazil and Tiles

    [题目链接]:http://codeforces.com/contest/515/problem/D [题意] 给你一个n*m的格子; 然后让你用1*2的长方形去填格子的空缺; 如果有填满的方案且方案 ...

随机推荐

  1. 一些css兼容问题

    由于各浏览器的不同,会存在一些兼容问题,特别是兼容IE6/7/8 下面简单介绍了一些解决方法,更多问题可以访问 W3help.org来查看. 可以通过js获取浏览器版本 document.body.i ...

  2. Lapack下载安装

    安装 1.下载压缩文件 wget http://www.netlib.org/lapack/lapack-3.8.0.tar.gz 2.解压缩 tar -zxvf lapack-3.8.0.tar.g ...

  3. [WPF] 圆形等待效果

    原文:[WPF] 圆形等待效果 自己做着玩儿的,留着以后用,效果类似下面的 GIF 动画. <Grid Width="35" Height="35"> ...

  4. 安装NexT主题

    Hexo 安装主题的方式非常简单,只需要将主题文件拷贝至站点目录的 themes 目录下, 然后修改下配置文件即可. 下载主题包 在终端窗口下,定位到 Hexo 站点目录下.使用 Git checko ...

  5. Nginx监控

    http://www.ttlsa.com/nginx/nginx-status-detail/ http://blog.csdn.net/bobpen/article/details/53431699 ...

  6. HDU 1131

    N个节点的不同的树的数目.这样 随便取一个节点作为根,那么他左边和右边的儿子节点个数就确定了,假定根节点标号为x,那么左子树的标号就从1到x-1,共x-1个,右子树的标号就从x+1到n,共n-x个,那 ...

  7. 【面试】-Java基础知识

    1.Java的工作原理 1) Java源程序(.java)须要通过编译器编译成字节码(.class)文件; 2) Java程序的跨平台主要指字节码能够在不论什么具有Java虚拟机的设备上运行: 3) ...

  8. php扩展之 pdo_mysql.so

    总结:新搭编译安装的 nginx+php+mysql环境,执行之前开发的项目遇到了没有安装pdo的问题 1.进入到php5的源代码包里面,ext以下.找到pdo_mysql目录 首先运行:/usr/l ...

  9. 本书已出版&lt;拨云见日:基于android的内核与系统架构源代码分析 &gt;

    已陆续倒到各大电商站点及新华书店 http://item.jd.com/11594135.html http://product.china-pub.com/4472138 http://www.am ...

  10. iOS 从各种效果图颜色标注生成 UIColor

    iOS 从各种效果图颜色标注生成 UIColor 太阳火神的漂亮人生 (http://blog.csdn.net/opengl_es) 本文遵循"署名-非商业用途-保持一致"创作公 ...