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

ACM___________________________

______________白白の屋
posts - 182, comments - 102, trackbacks - 0, articles - 0
<2010年10月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

常用鏈接

留言簿(24)

隨筆分類(332)

隨筆檔案(182)

FRIENDS

搜索

積分與排名

最新隨筆

最新評論

閱讀排行榜

評論排行榜

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

題目地址 :

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

題目描述:

Man Down

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 618    Accepted Submission(s): 197


Problem Description
The Game “Man Down 100 floors” is an famous and interesting game.You can enjoy the game from 
http://hi.baidu.com/abcdxyzk/blog/item/16398781b4f2a5d1bd3e1eed.html

We take a simplified version of this game. We have only two kinds of planks. One kind of the planks contains food and the other one contains nails. And if the man falls on the plank which contains food his energy will increase but if he falls on the plank which contains nails his energy will decrease. The man can only fall down vertically .We assume that the energy he can increase is unlimited and no borders exist on the left and the right.

First the man has total energy 100 and stands on the topmost plank of all. Then he can choose to go left or right to fall down. If he falls down from the position (Xi,Yi),he will fall onto the nearest plank which satisfies (xl <= xi <= xr)(xl is the leftmost position of the plank and xr is the rightmost).If no planks satisfies that, the man will fall onto the floor and he finishes his mission. But if the man’s energy is below or equal to 0 , he will die and the game is Over.

Now give you the height and position of all planks. And ask you whether the man can falls onto the floor successfully. If he can, try to calculate the maximum energy he can own when he is on the floor.(Assuming that the floor is infinite and its height is 0,and all the planks are located at different height).
 

Input
There are multiple test cases.

For each test case, The first line contains one integer N (2 <= N <= 100,000) representing the number of planks.

Then following N lines representing N planks, each line contain 4 integers (h,xl,xr,value)(h > 0, 0 < xl < xr < 100,000, -1000 <= value <= 1000), h represents the plank’s height, xl is the leftmost position of the plank and xr is the rightmost position. Value represents the energy the man will increase by( if value > 0) or decrease by( if value < 0) when he falls onto this plank.
 

Output
If the man can falls onto the floor successfully just output the maximum energy he can own when he is on the floor. But if the man can not fall down onto the floor anyway ,just output “-1”(not including the quote)
 

Sample Input
4 10 5 10 10 5 3 6 -100 4 7 11 20 2 2 1000 10
 

Sample Output
140
 

 /*

  題目描述:  

          不同高度處有不同的水平板,跳到該板會有血量變化v,

          問當一個人從最高板開始,可以向左或者向右,

          豎直跳到下面的板,求下落到地面的最大血量,或者-1。

          線段樹+dp  

          需要用線段樹查詢得到每個板的兩個端點下落后會到哪個板;

          然后根據這個從最高的開始dp就可以了

          dp[i] = max ( dp[i], dp[i^].v )  // dp[i^] 代表能走到 i 的線段 

/* 


/*

Mail to   : miyubai@gamil.com

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

Author By : MiYu

Test      : 1

Complier  : g++ mingw32-3.4.2

Program   : HDU_3016

Doc Name  : Man Down

*/

//#pragma warning( disable:4789 )

#include <iostream>

#include <fstream>

#include <sstream>

#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>

#include <ctime>

using namespace std;

struct seg_tree {

    int id, left, right;

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

}seg[333333];

inline void creat ( int x, int y, int rt = 1 ) {

     seg[rt].left = x;

     seg[rt].right = y;

     //0 代表地面 其他的自然數代表各層的木板編號  -1 代表有多條線段覆蓋 

     seg[rt].id = 0;                  

     if ( x == y ) return ;

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

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

     creat ( mid + 1, y, rt << 1 | 1 );     

}

inline void modify ( int x, int y, int id, int rt = 1 ) {

     //找到了線段, 直接修改ID 覆蓋掉 

     if ( seg[rt].left == x && seg[rt].right == y ) {

         seg[rt].id = id;

         return;   

     }

     int LL = rt << 1, RR = rt << 1 | 1, mid = seg[rt].mid();

     // 前面沒有return掉, 那么這條線段肯定是被覆蓋的, 將它的標記下傳后標記為-1 

     if ( seg[rt].id != -1 ) {      

         seg[LL].id = seg[RR].id = seg[rt].id;          

         seg[rt].id = -1;

     }      

     if ( y <= mid ) modify ( x, y, id, LL ); //分段修改 

     else if ( x > mid ) modify ( x, y, id, RR );

     else {

          modify ( x, mid, id, LL );

          modify ( mid + 1, y, id, RR );     

     }

}

inline int query ( int pos, int rt = 1 ) {   // 查詢 Pos 所在線段的 id  

    if ( seg[rt].id != -1 ) return seg[rt].id; //線段被覆蓋 直接返回 ID 

    int LL = rt << 1, RR = rt << 1 | 1, mid = seg[rt].mid();

    if ( pos <= mid ) return query ( pos, LL );             //分段查詢 

    else return query ( pos, RR );    

}

inline bool scan_d(int &num)  //整數輸入

{

        char in;bool IsN=false;

        in=getchar();

        if(in==EOF) return false;

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

        if(in=='-'){ IsN=true;num=0;}

        else num=in-'0';

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

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

        }

        if(IsN) num=-num;

        return true;

}

struct Plank {

       int x,y,h,v,left,right; 

       //按高排序       

       friend bool operator < ( const Plank &a, const Plank &b ) {

              return a.h < b.h;

       }

}pk[100010];

int dp[100010];

int main ()

{

    int N, M;

    creat ( 1, 100000 );

    while ( scan_d ( N ) ) {

           M = -1;

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

                scan_d ( pk[i].h );scan_d ( pk[i].x );scan_d ( pk[i].y );scan_d ( pk[i].v );

                if ( pk[i].y > M ) M = pk[i].y;       // 記錄 區間最大值, 加速用的 

           }

           modify  ( 1, M, 0 );

           sort ( pk + 1, pk + N + 1 );               // 按高排序 

           memset ( dp, 0, sizeof ( dp ) );

           dp[N] = 100 + pk[N].v;

           // 自底向上 更新 線段, 記錄 每條線段 左右端點能到達的 線段 ID 

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

                int x = pk[i].left = query ( pk[i].x );

                int y = pk[i].right = query ( pk[i].y );

                modify ( pk[i].x, pk[i].y, i );

           }

           int res = -1;

           //自頂向下 DP    dp[i] = max ( dp[i], dp[i^].v )  

           // dp[i^] 代表能走到 i 的線段 

           for ( int i = N; i >= 1; -- i ) {   

               if ( dp[ pk[i].left ] < dp[i] + pk[ pk[i].left ].v )

                    dp[ pk[i].left ] = dp[i] + pk[ pk[i].left ].v;

               if ( dp[ pk[i].right ] < dp[i] + pk[ pk[i].right ].v )

                    dp[ pk[i].right ] = dp[i] + pk[ pk[i].right ].v; 

           } 

           printf ( "%d\n",dp[0] > 0 ? dp[0] : -1 );

    }

    return 0;

}


 

 

Feedback

# re: HDU 3016 HDOJ 3016 Memory Control ACM 3016 IN HDU  回復  更多評論   

2010-10-18 19:21 by の屋
Google前n個搜索結果都和你的相關

# re: HDU 3016 HDOJ 3016 Man Down ACM 3016 IN HDU  回復  更多評論   

2010-10-30 07:51 by MiYu
表明哥 有 成 牛 的資質 =. = 嘿嘿

# re: HDU 3016 HDOJ 3016 Man Down ACM 3016 IN HDU  回復  更多評論   

2013-07-13 21:50 by fegnchen
pascal 版的有嗎??
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲三级网站| 亚洲综合久久久久| 麻豆成人在线| 亚洲肉体裸体xxxx137| 亚洲国产精品小视频| 欧美成年人视频| 99视频精品在线| 亚洲午夜一区二区| 国际精品欧美精品| 欧美国产日韩xxxxx| 欧美成年人视频网站欧美| 99日韩精品| 亚洲一区精品电影| 精品成人国产在线观看男人呻吟| 久久香蕉精品| 欧美喷潮久久久xxxxx| 亚洲欧美精品伊人久久| 欧美一区在线直播| 亚洲精品美女在线| 亚洲免费在线电影| 亚洲激情在线激情| 在线亚洲观看| 影音先锋日韩资源| 亚洲精品中文字| 国产一区二区三区四区老人| 欧美高清视频在线播放| 国产精品夫妻自拍| 欧美福利一区| 国产精品午夜电影| 欧美黄在线观看| 国产日韩欧美a| 亚洲日本一区二区| 狠狠久久综合婷婷不卡| 日韩视频在线一区| 亚洲大片av| 亚洲永久在线观看| 99日韩精品| 久热精品视频在线观看| 性欧美大战久久久久久久免费观看 | 欧美三级电影网| 老司机凹凸av亚洲导航| 国产精品成人一区二区网站软件| 狂野欧美激情性xxxx| 欧美婷婷久久| 亚洲国产日韩欧美在线图片 | 麻豆精品传媒视频| 久久国产精品第一页| 欧美片网站免费| 欧美高清视频免费观看| 国内精品一区二区| 亚洲自拍16p| 午夜精品久久99蜜桃的功能介绍| 欧美成人自拍| 欧美激情精品久久久久久免费印度| 国产精品亚洲第一区在线暖暖韩国| 亚洲黑丝在线| 亚洲欧洲一区| 久久综合999| 免费日韩一区二区| 黄色在线成人| 久久久福利视频| 久久精品国产欧美激情| 国产乱码精品1区2区3区| 一区二区三区高清在线观看| 99视频一区二区三区| 欧美成人蜜桃| 亚洲人人精品| 亚洲一区二区三区精品在线观看 | 久久久蜜桃精品| 老司机精品久久| 激情一区二区| 免费在线看一区| 亚洲肉体裸体xxxx137| 日韩视频免费观看高清在线视频| 美日韩精品视频| 亚洲人成小说网站色在线| 一区二区三区高清不卡| 国产精品国产福利国产秒拍| 亚洲一区二区精品| 欧美一区免费视频| 伊人成综合网伊人222| 老巨人导航500精品| 亚洲国产成人高清精品| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 国产日韩欧美制服另类| 久久久成人网| 亚洲国产欧美不卡在线观看| 中文亚洲欧美| 国产欧美一区二区三区国产幕精品| 午夜精品美女久久久久av福利| 欧美影院在线播放| 亚洲国产福利在线| 欧美日韩成人综合| 亚洲欧美一区在线| 麻豆精品网站| 在线一区二区三区四区| 国产日韩欧美视频| 欧美不卡视频一区| 亚洲欧美在线免费观看| 免费久久99精品国产自| 一区二区三区视频在线| 国产精品自在线| 久久天堂国产精品| 一区二区三区|亚洲午夜| 久久亚洲综合| 中文一区二区在线观看| 尤物yw午夜国产精品视频| 欧美日本网站| 欧美在线一区二区三区| 亚洲精品欧美日韩专区| 欧美在线一二三区| 一区二区日韩| 亚洲国产欧美精品| 国产九色精品成人porny| 欧美高清视频在线| 欧美在线播放一区| 99这里只有精品| 亚洲春色另类小说| 欧美精品在线网站| 欧美在线首页| 亚洲视屏在线播放| 亚洲欧洲精品天堂一级| 久久视频免费观看| 欧美在线看片| 亚洲免费在线看| 日韩一级裸体免费视频| 精品不卡在线| 国产日韩欧美视频在线| 国产精品久久久99| 欧美视频中文一区二区三区在线观看 | 裸体一区二区三区| 欧美在线视频观看| 亚洲在线视频免费观看| 亚洲剧情一区二区| 亚洲欧洲美洲综合色网| 欧美激情在线观看| 欧美刺激性大交免费视频| 久久久久久噜噜噜久久久精品| 亚洲欧美文学| 亚洲欧美另类久久久精品2019| 99riav1国产精品视频| 亚洲人成网站777色婷婷| 樱桃成人精品视频在线播放| 国内精品久久久久久久影视蜜臀| 国产欧美日韩在线观看| 国产精品午夜电影| 国产毛片精品视频| 国产亚洲精品久久飘花| 国产日韩精品一区观看| 国模精品一区二区三区| 一区精品久久| 亚洲国产一区二区视频| 亚洲青涩在线| 一区二区三区 在线观看视频| 99视频精品| 亚洲欧美中文另类| 久久国产一区二区| 狼人社综合社区| 亚洲国产专区| 一卡二卡3卡四卡高清精品视频| 亚洲图片你懂的| 欧美一区二区三区日韩视频| 欧美诱惑福利视频| 免费成人av在线| 欧美三日本三级三级在线播放| 国产精品欧美激情| 韩日欧美一区二区| 亚洲精品影院在线观看| 中文精品一区二区三区| 欧美在线观看一区| 免费成人高清在线视频| 亚洲欧洲精品一区二区三区波多野1战4| 日韩视频亚洲视频| 午夜视频一区在线观看| 久久亚洲国产精品日日av夜夜| 欧美精品v日韩精品v韩国精品v| 国产精品久久久久一区二区三区共 | 欧美国产亚洲精品久久久8v| 欧美日韩一级视频| 国产一区二区你懂的| 亚洲精品一区久久久久久| 亚洲欧美日韩一区二区| 免费观看成人鲁鲁鲁鲁鲁视频 | 久久综合导航| 亚洲免费成人av电影| 欧美一区二区三区日韩| 欧美久久综合| 激情欧美一区二区三区| 亚洲性xxxx| 免费在线观看日韩欧美| 中文国产亚洲喷潮| 免费在线看成人av| 国产亚洲精品资源在线26u| 亚洲最快最全在线视频| 久久婷婷国产麻豆91天堂| 99精品热视频| 欧美成人情趣视频| 在线不卡a资源高清| 亚洲欧美另类国产| 亚洲精品色图|