青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

ACM___________________________

______________白白の屋
posts - 182, comments - 102, trackbacks - 0, articles - 0
<2010年8月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
2930311234

常用鏈接

留言簿(24)

隨筆分類(332)

隨筆檔案(182)

FRIENDS

搜索

積分與排名

最新隨筆

最新評論

閱讀排行榜

評論排行榜


MiYu原創, 轉帖請注明 : 轉載自 ______________白白の屋    

 

題目地址:

 http://acm.hdu.edu.cn/showproblem.php?pid=2795

題目描述:

Billboard

Time Limit: 20000/8000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 733    Accepted Submission(s): 340


Problem Description
At the entrance to the university, there is a huge rectangular billboard of size h*w (h is its height and w is its width). The board is the place where all possible announcements are posted: nearest programming competitions, changes in the dining room menu, and other important information.

On September 1, the billboard was empty. One by one, the announcements started being put on the billboard.

Each announcement is a stripe of paper of unit height. More specifically, the i-th announcement is a rectangle of size 1 * wi.

When someone puts a new announcement on the billboard, she would always choose the topmost possible position for the announcement. Among all possible topmost positions she would always choose the leftmost one.

If there is no valid location for a new announcement, it is not put on the billboard (that's why some programming contests have no participants from this university).

Given the sizes of the billboard and the announcements, your task is to find the numbers of rows in which the announcements are placed.
 

Input
There are multiple cases (no more than 40 cases).

The first line of the input file contains three integer numbers, h, w, and n (1 <= h,w <= 10^9; 1 <= n <= 200,000) - the dimensions of the billboard and the number of announcements.

Each of the next n lines contains an integer number wi (1 <= wi <= 10^9) - the width of i-th announcement.
 

Output
For each announcement (in the order they are given in the input file) output one number - the number of the row in which this announcement is placed. Rows are numbered from 1 to h, starting with the top row. If an announcement can't be put on the billboard, output "-1" for this announcement.
 

Sample Input
3 5 5 2 4 3 3 3
 

Sample Output
1 2 1 3 -1
 

 

一開始沒想明白怎么做 ,  仔細想了想,   再次 讀題后 發現 , n <= 200000;  也就是說  最多 也就 200000 條廣告 , 你就算每行貼一張 ,

最多也就貼到 200000 行,  所以  不要被  h <= 10^9  次方嚇到了  ,認為 線段樹開不了那么大的數組  . 只要開 200000 就可以了 .

 

其他的 沒什么 好說的 , 知道這個 就直接 暴 吧 ............將近 7000MS .=水過.................   g++提交 還華麗的 送出了 一次 TLE....

C++  水過了 ............

 

//    一直沒明白 為什么我的 代碼速度 那么 慢,  查詢后 更新 的時間是 2000MS 左右  , 我的 是 查詢 就更新了,

竟然要 將近 7000MS ? 非常 郁悶 ,  不信邪的 繼續 檢查 代碼, 在 瞪了 1哥小時后 , 忽然想到 : 把 cout 改成

printf 會怎樣?   結果 :  1640 MS  AC ..............鬼知道他的 數據量有多大..... cout 和 printf

竟然 差了 5000 MS 的時間 ...........無語

代碼如下 :

 

 /*

Coded By  : MiYu

Link      : http://www.cnblogs.com/MiYu  || http://m.shnenglu.com/MiYu

Author By : MiYu

Test      : 1

Program   : 2795

*/

//#pragma warning( disable:4789 )

#include <iostream>

#include <algorithm>

#include <string>

#include <set>

#include <map>

#include <utility>

#include <queue>

#include <stack>

#include <list>

#include <vector>

#include <cstdio>

#include <cstdlib>

#include <cstring>

#include <cmath>

using namespace std;


struct ADV {

       int left, right, val;

       int mid () { return ( left + right ) >> 1; }     

}adv[800000];

int N, W, H, w;

void creat ( int l, int r, int rt = 1 ){

     adv[rt].left = l;

     adv[rt].right = r;

     adv[rt].val = W;

     if ( l == r )

        return ;

     int mid = adv[rt].mid();

     creat ( l, mid, rt << 1 );

     creat ( mid + 1, r, ( rt << 1 ) + 1 );

}

void add ( int rt = 1, int wei = w ){

    if ( wei <= adv[rt].val ){

         if ( adv[rt].left == adv[rt].right ){

              adv[rt].val -= wei;

              //cout << adv[rt].left << endl;  //杯具的 地方

printf ( "%d\n", adv[rt].left ); 

              return ;     

         } else if ( adv[rt<<1].val >= wei ) {

                add ( rt << 1 );

                adv[rt].val = max ( adv[rt<<1].val, adv[(rt<<1)+1].val );     

         } else {

                add ( ( rt << 1 ) + 1 );

                adv[rt].val = max ( adv[rt<<1].val, adv[(rt<<1)+1].val );        

         }   

    } else {

           //cout << -1 << endl;      //杯具的地方

puts ( "-1" );   

    }   

}

inline bool scan_ud(int &num)

{

    char in;

    in=getchar();

    if(in==EOF) return false;

    while(in<'0'||in>'9') in=getchar();

    num=in-'0';

    while(in=getchar(),in>='0'&&in<='9'){

        num*=10,num+=in-'0';

    }

    return true;

}

int main ()

{

    while ( scan_ud (H)&&scan_ud (W)&&scan_ud (N) ) {

           if ( H > 200000 )

               H = 200010;

           creat ( 1, H );

           for ( int i = 1; i <= N; ++ i ) {

                scan_ud (w);

                add ( );     

           }      

    }

    return 0;

}

 

 

 

 

另 附上 傻崽  神牛 代碼 :

 

#include <iostream>

#include <algorithm>

#include <string>

#include <set>

#include <map>

#include <utility>

#include <queue>

#include <stack>

#include <list>

#include <vector>

#include <cstdio>

#include <cstdlib>

#include <cstring>

#include <cmath>

#define FF(i,a) for( int i = 0 ; i < a ; i ++ )

#define FOR(i,a,b) for( int i = a ; i < b ; i ++ )

#define LL(a) a<<1

#define RR(a) a<<1|1

template<class T> inline void checkmin(T &a,T b) {if(a < 0 || a > b)a = b;}

template<class T> inline void checkmax(T &a,T b) {if(a < b) a = b;}

using namespace std;

struct Node {

int val;

int idx;

friend bool operator < (Node a , Node b) {

if(a.val == b.val) {

return a.idx > b.idx;

}

return a.val < b.val;

}

}error;

 

struct Seg_Tree{

int left,right;

Node node;

int mid() {

return (left + right)>>1;

}

}tt[800000];

 

int n , h , m;

 

void build(int l,int r,int idx) {

tt[idx].left = l;

tt[idx].right = r;

tt[idx].node.idx = l;

tt[idx].node.val = h;

if(l == r) return ;

int mid = tt[idx].mid();

build(l,mid,LL(idx));

build(mid+1,r,RR(idx));

}

 

void update(int l,int r,int val,int idx) {

if(l <= tt[idx].left && r >= tt[idx].right) {

tt[idx].node.val += val;

return ;

}

int mid = tt[idx].mid();

if(l <= mid) update(l,r,val,LL(idx));

if(mid < r) update(l,r,val,RR(idx));

tt[idx].node = max(tt[LL(idx)].node,tt[RR(idx)].node);

}

 

Node query(int w,int idx) {

if(tt[idx].node.val < w) {

return error;

}

if(tt[idx].left == tt[idx].right) {

return tt[idx].node;

}

if(tt[LL(idx)].node.val >= w) {

return query(w,LL(idx));

} else {

return query(w,RR(idx));

}

}

 

int main() {

error.idx = -1;

while(scanf("%d%d%d",&n,&h,&m) == 3) {

checkmin(n,m);

build(1,n,1);

while(m --) {

int w;

scanf("%d",&w);

Node ret = query(w,1);

printf("%d\n",ret.idx);

if(ret.idx != -1) {

update(ret.idx,ret.idx,-w,1);

}

}

}

return 0;

 

 

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲三级影院| 欧美在线视频免费观看| 欧美激情精品久久久久| 久久精品国产在热久久| 韩国一区电影| 欧美大片免费观看| 欧美jjzz| 亚洲小说欧美另类社区| 亚洲综合第一| 激情久久五月| 91久久香蕉国产日韩欧美9色| 欧美顶级大胆免费视频| 中文国产一区| 午夜精品一区二区三区在线| 黄色一区二区在线观看| 亚洲国产精品高清久久久| 欧美精品1区| 亚洲男人的天堂在线观看| 欧美一区国产二区| 日韩写真视频在线观看| 亚洲一区二区三区在线观看视频| 国产亚洲欧美日韩在线一区| 欧美国产日产韩国视频| 国产精品久久中文| 欧美成人a∨高清免费观看| 欧美日韩极品在线观看一区| 久久精品一区四区| 欧美精品一区二区高清在线观看| 久久爱另类一区二区小说| 麻豆成人av| 先锋亚洲精品| 欧美激情第五页| 久久嫩草精品久久久精品一| 欧美巨乳在线| 欧美成人激情视频免费观看| 国产精品视频导航| 亚洲国产精品一区二区www在线| 国产精品久久福利| 亚洲国产精品传媒在线观看 | 午夜精品久久久久久| 在线观看成人av| 亚洲一级特黄| 亚洲视频一区二区| 麻豆久久精品| 久久亚洲国产精品日日av夜夜| 欧美三级在线播放| 亚洲福利专区| 亚洲成人在线网站| 久久精品国产欧美激情| 亚洲欧美中文日韩v在线观看| 欧美成人免费观看| 蜜臀av一级做a爰片久久 | 欧美主播一区二区三区美女 久久精品人| 亚洲欧洲一区二区在线播放| 久久九九99| 久久久久久尹人网香蕉| 国产精品影视天天线| 这里只有精品视频| 99re6热只有精品免费观看| 久久综合福利| 玖玖在线精品| 在线观看精品一区| 久久久久网址| 男人的天堂亚洲| 一区二区视频欧美| 久久久久九九九九| 欧美成人有码| 亚洲激情午夜| 欧美高清在线| 亚洲欧洲一区二区三区在线观看| 亚洲三级影院| 欧美精品一区二区久久婷婷| 亚洲国产一区二区三区a毛片| 亚洲欧洲综合另类| 欧美日韩爆操| 亚洲天堂久久| 久久国产精品99精品国产| 国产亚洲美州欧州综合国| 新狼窝色av性久久久久久| 久久久午夜电影| 亚洲国产精品悠悠久久琪琪| 你懂的视频欧美| 日韩视频永久免费观看| 午夜精品一区二区三区四区| 国产亚洲福利一区| 久久人人九九| 亚洲日本国产| 香蕉久久a毛片| 激情久久久久久久| 免费久久99精品国产| 亚洲人线精品午夜| 亚洲欧美日韩一区二区三区在线| 国产午夜精品在线观看| 久久婷婷国产综合尤物精品| 亚洲精品国久久99热| 午夜一区二区三区不卡视频| 国产视频精品va久久久久久| 久久综合九色综合欧美就去吻 | 免费在线欧美黄色| 一区二区三区日韩欧美精品| 国产精品自拍三区| 美女性感视频久久久| 一本色道久久综合亚洲精品婷婷 | 中文日韩在线| 另类国产ts人妖高潮视频| 一本色道久久99精品综合| 国产视频丨精品|在线观看| 欧美国产第一页| 欧美在线视频播放| 99精品欧美一区二区三区 | 亚洲一二三区在线| 国产真实乱偷精品视频免| 欧美成人一区二区三区| 亚洲一区在线视频| 亚洲日本理论电影| 久久久久久夜| 亚洲免费在线精品一区| 亚洲第一黄色网| 国产欧美一区二区白浆黑人| 欧美成人午夜77777| 久久国产精彩视频| 亚洲天堂av在线免费观看| 91久久精品国产91性色| 巨乳诱惑日韩免费av| 午夜精品在线看| 亚洲天堂男人| 亚洲美女毛片| 亚洲区在线播放| 一区二区三区在线免费观看| 国产欧美欧洲在线观看| 欧美午夜不卡在线观看免费 | 国产人久久人人人人爽| 欧美日韩亚洲91| 欧美激情一区二区久久久| 久久亚洲图片| 久久亚洲色图| 久热成人在线视频| 看欧美日韩国产| 久久久久网站| 老司机成人在线视频| 久久精品免费电影| 久久久久国产精品厨房| 欧美在线观看视频在线| 午夜亚洲激情| 久久av一区二区三区| 欧美亚洲综合在线| 欧美一二三区在线观看| 久久成人免费视频| 欧美一区激情| 久久久噜噜噜久噜久久 | 在线视频你懂得一区| 一本一本a久久| 亚洲一区二区免费视频| 亚洲视频中文| 欧美一级欧美一级在线播放| 欧美一级专区免费大片| 久久久精品国产免大香伊| 老色批av在线精品| 欧美人与性动交cc0o| 欧美三级视频在线| 国产日韩亚洲| 亚洲国产精品精华液2区45| 亚洲人成网站在线观看播放| 亚洲视频电影在线| 欧美影院在线| 蜜臀av在线播放一区二区三区| 亚洲国产高清一区二区三区| 亚洲乱码国产乱码精品精98午夜| 中文精品视频| 久久精品人人| 欧美人与禽性xxxxx杂性| 国产精品私拍pans大尺度在线| 国产亚洲第一区| 亚洲九九九在线观看| 亚洲欧美成人一区二区在线电影| 久久精品男女| 亚洲人成欧美中文字幕| 亚洲欧美日本国产有色| 久久综合九色99| 国产精品久久久久久亚洲毛片 | 国精品一区二区| 最新日韩在线| 午夜在线视频观看日韩17c| 麻豆精品在线观看| 一区二区三区欧美成人| 久久夜色精品亚洲噜噜国产mv| 欧美日韩国产精品自在自线| 国产偷久久久精品专区| 夜夜嗨av一区二区三区四区| 久久精品人人做人人爽电影蜜月| 最近中文字幕mv在线一区二区三区四区| 一区二区高清| 欧美激情按摩| 精品成人在线| 欧美一区二区三区在线| 日韩午夜电影| 欧美jizz19hd性欧美| 国内自拍亚洲| 亚洲欧美日韩国产一区| 亚洲日本理论电影|