B. Preparing for the Contest

题目连接:

http://codeforces.com/contest/377/problem/B

Description

Soon there will be held the world's largest programming contest, but the testing system still has m bugs. The contest organizer, a well-known university, has no choice but to attract university students to fix all the bugs. The university has n students able to perform such work. The students realize that they are the only hope of the organizers, so they don't want to work for free: the i-th student wants to get ci 'passes' in his subjects (regardless of the volume of his work).

Bugs, like students, are not the same: every bug is characterized by complexity aj, and every student has the level of his abilities bi. Student i can fix a bug j only if the level of his abilities is not less than the complexity of the bug: bi ≥ aj, and he does it in one day. Otherwise, the bug will have to be fixed by another student. Of course, no student can work on a few bugs in one day. All bugs are not dependent on each other, so they can be corrected in any order, and different students can work simultaneously.

The university wants to fix all the bugs as quickly as possible, but giving the students the total of not more than s passes. Determine which students to use for that and come up with the schedule of work saying which student should fix which bug.

Input

The first line contains three space-separated integers: n, m and s (1 ≤ n, m ≤ 105, 0 ≤ s ≤ 109) — the number of students, the number of bugs in the system and the maximum number of passes the university is ready to give the students.

The next line contains m space-separated integers a1, a2, ..., am (1 ≤ ai ≤ 109) — the bugs' complexities.

The next line contains n space-separated integers b1, b2, ..., bn (1 ≤ bi ≤ 109) — the levels of the students' abilities.

The next line contains n space-separated integers c1, c2, ..., cn (0 ≤ ci ≤ 109) — the numbers of the passes the students want to get for their help.

Output

If the university can't correct all bugs print "NO".

Otherwise, on the first line print "YES", and on the next line print m space-separated integers: the i-th of these numbers should equal the number of the student who corrects the i-th bug in the optimal answer. The bugs should be corrected as quickly as possible (you must spend the minimum number of days), and the total given passes mustn't exceed s. If there are multiple optimal answers, you can output any of them.

Sample Input

3 4 9

1 3 1 2

2 1 3

4 3 6

Sample Output

YES

2 3 2 3

Hint

题意

有一个学校,有m个bug,有n个大学生,每个大学生的能力值是b[i],bug的能力值是a[i],如果b[i]>=a[j],那么第i个人能够修复j bug

现在每个大学生你需要支付c[i]元,支付给他之后,他可以每天修复一个能力值小于等于他能力值的bug

你需要尽量少的天数,以及在花费小于s的情况下,修复这些bug

问你怎么去做?

题解:

如果能在T天修复完,那么显然也能够在T+1天内修复完,所以这个是具备二分性的

然后我们就二分答案,那么我们找到一个最便宜的人去修复[m,m-T+1]的bug,再找一个人去修复[m-T,m-2T+1],等等等

这样就好了

然后我们用一个线段树去维护这个玩意儿就好了

代码

#include <bits/stdc++.h>

using namespace std;

const int maxn = 1e5 + 15;

struct Person{
int cost , val , idx ;
friend bool operator < (const Person & a , const Person & b){
return a.val < b.val;
}
}p[maxn];
int N , M , S , maxv , ans[maxn]; pair < int , int > a[maxn]; bool cmp( const pair < int , int > & x , const pair < int , int > & y){
return x.first > y.first;
} struct Sgtree{ struct node{
int l , r ;
int pos , minv;
}tree[maxn << 2]; void Maintain( int o ){
int lson = o << 1 , rson = o << 1 | 1;
if( tree[lson].minv < tree[rson].minv ) tree[o].minv = tree[lson].minv , tree[o].pos = tree[lson].pos;
else tree[o].minv = tree[rson].minv , tree[o].pos = tree[rson].pos;
} void Build( int l , int r , int o ){
tree[o].l = l , tree[o].r = r ;
if( r > l ){
int mid = l + r >> 1;
Build( l , mid , o << 1 );
Build( mid + 1 , r , o << 1 | 1 );
Maintain( o );
}else tree[o].pos = l , tree[o].minv = p[l].cost;
} void Modify( int p , int o ){
int l = tree[o].l , r = tree[o].r;
if( l == r ) tree[o].minv = 2e9;
else{
int mid = l + r >> 1;
if( p <= mid ) Modify( p , o << 1 );
else Modify( p , o << 1 | 1 );
Maintain( o );
}
} pair < int , int > ask( int ql , int o ){
int l = tree[o].l , r = tree[o].r;
if(ql <= l) return make_pair( tree[o].minv , tree[o].pos );
else{
int mid = l + r >> 1;
pair < int , int > ls , rs ;
ls.first = rs.first = 2e9;
if( ql <= mid ) ls = ask( ql , o << 1 );
rs = ask( ql , o << 1 | 1 );
if( ls.first < rs.first ) return ls;
return rs;
}
} }Sgtree; bool solve( int T ){
Sgtree.Build(1 , N , 1);
vector < int > vi;
int j = N , money = S;
for(int i = 1 ; i <= M ; i += T){
while( j >= 1 && p[j].val >= a[i].first ) -- j;
pair < int , int > rp = Sgtree.ask( j + 1 , 1 );
if( rp.first > money ) return false;
money -= rp.first;
Sgtree.Modify(rp.second , 1);
vi.push_back( p[rp.second].idx );
}
int lst = 0 , ptr = 0;
for(int i = 1 ; i <= M ; ++ i){
ans[a[i].second] = vi[ptr];
++ lst;
if( lst == T ) lst = 0 , ++ ptr;
}
return true;
} int main( int argc , char * argv[] ){
scanf("%d%d%d",&N,&M,&S);
for(int i = 1 ; i <= M ; ++ i){
scanf("%d" , &a[i].first);
a[i].second = i;
maxv = max( maxv , a[i].first );
}
int find = 0;
for(int i = 1 ; i <= N ; ++ i) scanf("%d" , &p[i].val);
for(int i = 1 ; i <= N ; ++ i){
scanf("%d" , &p[i].cost);
p[i].idx = i ;
if( p[i].val >= maxv && p[i].cost <= S ) find = 1;
}
if( find == 0 ) printf("NO\n");
else{
sort( a + 1 , a + M + 1 , cmp );
sort( p + 1 , p + N + 1 );
int l = 1 , r = max(N,M);
while( l < r ){
int mid = l + r >> 1;
if( solve( mid ) ) r = mid;
else l = mid + 1;
}
solve( l );
printf("YES\n");
for(int i = 1 ; i <= M ; ++ i) printf("%d ", ans[i]);
printf("\n");
}
return 0;
}

Codeforces Round #222 (Div. 1) B. Preparing for the Contest 二分+线段树的更多相关文章

  1. Codeforces Round #365 (Div. 2) D. Mishka and Interesting sum 离线+线段树

    题目链接: http://codeforces.com/contest/703/problem/D D. Mishka and Interesting sum time limit per test ...

  2. Codeforces Round #538 (Div. 2) F 欧拉函数 + 区间修改线段树

    https://codeforces.com/contest/1114/problem/F 欧拉函数 + 区间更新线段树 题意 对一个序列(n<=4e5,a[i]<=300)两种操作: 1 ...

  3. Codeforces Round #345 (Div. 1) D. Zip-line 上升子序列 离线 离散化 线段树

    D. Zip-line 题目连接: http://www.codeforces.com/contest/650/problem/D Description Vasya has decided to b ...

  4. Codeforces Round #370 (Div. 2) E. Memory and Casinos (数学&&概率&&线段树)

    题目链接: http://codeforces.com/contest/712/problem/E 题目大意: 一条直线上有n格,在第i格有pi的可能性向右走一格,1-pi的可能性向左走一格,有2中操 ...

  5. Codeforces Round #FF (Div. 2)__E. DZY Loves Fibonacci Numbers (CF447) 线段树

    http://codeforces.com/contest/447/problem/E 题意: 给定一个数组, m次操作, 1 l r 表示区间修改, 每次 a[i] +  Fibonacci[i-l ...

  6. Codeforces Round #250 (Div. 1) D. The Child and Sequence(线段树)

    D. The Child and Sequence time limit per test 4 seconds memory limit per test 256 megabytes input st ...

  7. DFS Codeforces Round #306 (Div. 2) B. Preparing Olympiad

    题目传送门 /* DFS: 排序后一个一个出发往后找,找到>r为止,比赛写了return : */ #include <cstdio> #include <iostream&g ...

  8. Codeforces Round #367 (Div. 2) D. Vasiliy's Multiset (0/1-Trie树)

    Vasiliy's Multiset 题目链接: http://codeforces.com/contest/706/problem/D Description Author has gone out ...

  9. Codeforces Round #222 (Div. 1) (ABCDE)

    377A Maze 大意: 给定棋盘, 保证初始所有白格连通, 求将$k$个白格变为黑格, 使得白格仍然连通. $dfs$回溯时删除即可. #include <iostream> #inc ...

随机推荐

  1. TableView 的那些坑

    1. 分割线填满cell宽度, 并且设置分割线的颜色 1.1 利用系统的分割线填充 1.1.1 tableView 设置如下属性 // 给tableView设置如下属性值 tableView.layo ...

  2. DevExpress GridControl 的数据绑定

    本人不才啊,折腾2个多小时才把数据绑定好.现在把折腾过程记录一下来以帮助更多的朋友,自己也温习一下. 直接上代码了哈.... WPF哈 xaml文件 <dxg:GridControl Name= ...

  3. go语言项目汇总

    Horst Rutter edited this page 7 days ago · 529 revisions Indexes and search engines These sites prov ...

  4. GitHub安装和使用

    GitHub是一个基于git的代码托管平台,付费用户可以建私人仓库,一般的免费用户只能使用公共仓库,也就是代码要公开. Github 由Chris Wanstrath, PJ Hyett 与Tom P ...

  5. Win10搜索不能用

    使用win10进行搜索时,一直显示win10特色的滚动条,但就是检索不出东西,我的主要是检索不到windows的内容: (个人感觉使用win10检索网页内容不太专业,就关闭了Web搜索) 最后有发现网 ...

  6. java基础24 线程、多线程及线程的生命周期(Thread)

    1.1.进程 正在执行的程序称作为一个进程.进程负责了内存空间的划分 疑问1:windows电脑称之为多任务的操作系统,那么Windows是同时运行多个应用程序呢? 从宏观的角度:windows确实在 ...

  7. jpql和sql的区别

    项目使用jpa规范 其中既可使用面对对象查询(jpql语句) 又可使用原生sql查询; 1.(经后期验证,jpql都可以) 其中有一个区别是: jpql查询字段为空:  " cr.owner ...

  8. JAVA随笔(二)

    在函数传参时,double传给int是不行的,反过来可以.参数只能传值.当参数是字符串时,传递的只是串值:但对于数组来说,传递的是管理权,也就是指针 对象变量是对象管理者. cast转型:基本类型与对 ...

  9. 奇妙的CSS之CSS3新特性总结

    随着CSS3标准的发布,越来越多的浏览器开始支持最新的CSS标准,虽然还有些新特性支持的不够完美,但相信未来的浏览器一定会完全支持CSS3的,毕竟这代表着大趋势!下面l列出来一些CSS3中出现的新特性 ...

  10. DOS命令大全(二)

    一般来说dos命令都是在dos程序中进行的,如果电脑中安装有dos程序可以从开机选项中选择进入,在windows 系统中我们还可以从开始运行中输入cmd命令进入操作系统中的dos命令,如下图: 严格的 ...