码迷,mamicode.com
首页 > 其他好文 > 详细

hdu2795

时间:2014-11-18 23:40:54      阅读:165      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   io   ar   color   os   sp   for   

  题意:有一个h*w的木板,放置一些1*L的物品,将物品尽可能的往上面和左边放置。

  思路:维护一个区间的可以容纳板子长度的最大值

 

  AC代码:

  

bubuko.com,布布扣
 1 #include <cstdio>
 2 #include <iostream>
 3 #include <cstring>
 4 #include <cmath>
 5 #include <algorithm>
 6 #include <cstdlib>
 7 
 8 using namespace std;
 9 
10 const int maxn = 200000 + 10;
11 
12 int h, w, n, x;
13 
14 struct node
15 {
16     int l, r, v;
17 
18 } b[maxn<<2];
19 
20 void build(int l, int r, int i)
21 {
22     b[i].l = l;
23     b[i].r = r;
24     int m = (l + r) >> 1;
25     if(l == r) {
26         b[i].v = w;
27         return ;
28     }
29     build(l, m, i<<1);
30     build(m+1, r, i<<1|1);
31     b[i].v = max(b[i<<1].v, b[i<<1|1].v);
32 }
33 
34 int Query(int id, int num, int i)
35 {
36     int ret;
37     if(b[i].l == b[i].r) {
38         b[i].v -= num;
39         return b[i].l;
40     }
41     else {
42         if(num <= b[i<<1].v) ret = Query(id, num, i<<1);
43         else ret = Query(id, num, i<<1|1);
44     }
45     b[i].v = max(b[i<<1].v, b[i<<1|1].v);
46     return ret;
47 }
48 
49 int main()
50 {
51     //freopen("test.in", "r", stdin);
52     while(scanf("%d%d%d", &h, &w, &n) != EOF) {
53         int H = min(h, n);
54         build(1, H, 1);
55         for(int i = 1; i <= n; i++) {
56             scanf("%d", &x);
57             if(b[1].v < x) puts("-1");
58             else printf("%d\n", Query(1, x, 1));
59         }
60     }
61     return 0;
62 }
View Code

 

hdu2795

标签:style   blog   http   io   ar   color   os   sp   for   

原文地址:http://www.cnblogs.com/sayeter/p/3913588.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!