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

糯米

TI DaVinci, gstreamer, ffmpeg
隨筆 - 167, 文章 - 0, 評論 - 47, 引用 - 0
數(shù)據(jù)加載中……

POJ 2374 Fence Obstacle Course 線段樹+動態(tài)規(guī)劃

思路:

用線段樹維護所有線段的分布。
新增加一個fence的時候,將fence的范圍[a, b]插入線段樹,節(jié)點的值為fence的編號,即高度。
那么fence上的某一點就是樹的葉子了,從葉子往上一直到根節(jié)點的路徑中節(jié)點的最大值,
就是從fence上的這一點垂直掉下去后,碰到的一個fence了。

這樣,我們就可以在O(lgN)時間內(nèi)知道,從一個fence的端點掉下去會碰到哪個fence了。
不然從后往前一個個找就是O(N)復(fù)雜度了。同時N也很大,必然超時。

同時也可以發(fā)現(xiàn),一個fence保存兩個值用作動態(tài)規(guī)劃就好了,向左、右走之后,掉到其他fence上面,然后回到基地所用的最短路徑。
推的方法很簡單,掉到其他fence上面之后,看下是向左走距離短還是向右走距離短。就行了。

這個代碼跑到400ms。

#include <stdio.h>

#define MAX_N 50032
#define MAX_R 100032 

struct {
    
int a, b;
}
 dp[MAX_N], fences[MAX_N];
int N, S, tree[MAX_R*16];

__inline 
int max(int a, int b)
{
    
return a > b ? a : b;
}


__inline 
int abs(int a)
{
    
return a > 0 ? a : -a;
}


__inline 
int min(int a, int b)
{
    
return a < b ? a : b;
}


void insert(int idx, int start, int end, int left, int right, int val)
{
    
int mid;

    
if (start == left && right == end) {
        tree[idx] 
= val;
        
return ;
    }

    mid 
= (start + end) / 2;
    
if (right <= mid) 
        insert(idx
*2, start, mid, left, right, val);
    
else if (left > mid)
        insert(idx
*2+1, mid + 1, end, left, right, val);
    
else {
        insert(idx
*2, start, mid, left, mid, val);
        insert(idx
*2+1, mid + 1, end, mid + 1, right, val);
    }

}


int query(int idx, int start, int end, int pos)
{
    
int val, mid;

    
if (start == pos && end == pos) 
        
return tree[idx];
    mid 
= (start + end) / 2;
    
if (pos <= mid)
        val 
= query(idx*2, start, mid, pos);
    
else
        val 
= query(idx*2+1, mid + 1, end, pos);
    
return max(val, tree[idx]);
}


__inline 
int calc_min(int i, int pos)
{
    
if (!i)
        
return abs(pos - MAX_R);
    
return min(pos - fences[i].a + dp[i].a, fences[i].b - pos + dp[i].b);
}


int main()
{
    
int i;

    freopen(
"e:\\test\\in.txt""r", stdin);

    scanf(
"%d%d"&N, &S);
    S 
+= MAX_R;
    
for (i = 1; i <= N; i++{
        scanf(
"%d%d"&fences[i].a, &fences[i].b);
        fences[i].a 
+= MAX_R;
        fences[i].b 
+= MAX_R;
        dp[i].a 
= calc_min(query(10, MAX_R*2, fences[i].a), fences[i].a);
        dp[i].b 
= calc_min(query(10, MAX_R*2, fences[i].b), fences[i].b);
        insert(
10, MAX_R*2, fences[i].a, fences[i].b, i);
    }

    printf(    
"%d\n"
            min(S 
- fences[N].a + dp[N].a, fences[N].b - S + dp[N].b)
            );

    
return 0;
}

posted on 2010-03-08 18:21 糯米 閱讀(1384) 評論(2)  編輯 收藏 引用 所屬分類: POJ

評論

# re: POJ 2374 Fence Obstacle Course 線段樹+動態(tài)規(guī)劃  回復(fù)  更多評論   

知道為什么要用線段樹,我直接開辟一個數(shù)組,每次將第i個fense的區(qū)間標記為i,好像也能得到正確的結(jié)果,可是會運行超時,不知道為什么?
#include "stdafx.h"
#include <stdio.h>

#define MAX_N 50032
#define MAX_R 100032

struct {
int a, b;
} dp[MAX_N], fences[MAX_N];
int N, S;

int seg[MAX_R*2];

__inline int max(int a, int b)
{
return a > b ? a : b;
}

__inline int abs(int a)
{
return a > 0 ? a : -a;
}

__inline int min(int a, int b)
{
return a < b ? a : b;
}

__inline int calc_min(int i, int pos)
{
if (!i)
return abs(pos - MAX_R);
return min(pos - fences[i].a + dp[i].a, fences[i].b - pos + dp[i].b);
}


int main()
{
//for(int k=0;k<MAX_R*2;++k)
//{
// seg[k] = 0;
//}

int i;

freopen("e:\\test\\in.txt", "r", stdin);

scanf("%d%d", &N, &S);
S += MAX_R;
for (i = 1; i <= N; i++) {
scanf("%d%d", &fences[i].a, &fences[i].b);
fences[i].a += MAX_R;
fences[i].b += MAX_R;
dp[i].a = calc_min( seg[ fences[i].a ], fences[i].a);
dp[i].b = calc_min( seg[ fences[i].b ], fences[i].b);

for (int j=fences[i].a;j<=fences[i].b;++j)
{
seg[j] = i;
}

}
printf( "%d\n",
min(S - fences[N].a + dp[N].a, fences[N].b - S + dp[N].b)
);

return 0;
}
2012-01-29 01:28 | CWQBUPT

# re: POJ 2374 Fence Obstacle Course 線段樹+動態(tài)規(guī)劃  回復(fù)  更多評論   

@CWQBUPT
因為你缺少了二分的過程,線段樹查找O(logn),而你的查找O(n)
2016-05-07 21:20 | hez2010
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧美日韩国产中文| 在线视频亚洲一区| 欧美日韩免费一区二区三区| 欧美a级一区二区| 久久噜噜亚洲综合| 噜噜噜91成人网| 欧美精品激情在线观看| 欧美日韩视频免费播放| 国产精品久久久爽爽爽麻豆色哟哟| 欧美日韩中文字幕| 国产精品视频专区| 在线不卡a资源高清| 日韩亚洲国产欧美| 欧美中文在线视频| 欧美黄色免费网站| 亚洲欧美国产77777| 美女图片一区二区| 国产精品久久国产精品99gif| 国产欧美在线看| 亚洲国产精品999| 午夜精品一区二区三区在线播放| 久久免费视频在线观看| 亚洲精品一区二区三区蜜桃久| 一区二区三区四区蜜桃| 欧美在线精品一区| 欧美日韩精品免费观看视频完整| 国产精品综合| 99精品国产在热久久婷婷| 久久福利电影| 夜夜嗨av一区二区三区网站四季av| 午夜一区二区三区不卡视频| 欧美激情一区| 一区免费观看视频| 性欧美长视频| 日韩手机在线导航| 老司机67194精品线观看| 国产精品亚洲人在线观看| 亚洲精品五月天| 裸体歌舞表演一区二区| 亚洲综合成人在线| 欧美日韩伦理在线免费| 亚洲国产高清aⅴ视频| 久久国产欧美| 中文在线资源观看网站视频免费不卡| 久久精品夜色噜噜亚洲aⅴ | 亚洲精品麻豆| aⅴ色国产欧美| 亚洲午夜性刺激影院| 老司机午夜精品视频在线观看| 9国产精品视频| 欧美精品日韩一区| 亚洲日本欧美| 免费在线观看一区二区| 欧美一区二区久久久| 国产精品青草综合久久久久99| 一区二区国产精品| 亚洲国产精品传媒在线观看 | 亚洲桃色在线一区| 亚洲国产精品一区二区久| 久久综合影音| 亚洲成人在线视频网站| 另类成人小视频在线| 欧美在线免费| 激情丁香综合| 欧美国产综合| 欧美激情一区在线| 在线视频欧美日韩精品| 一本色道久久88综合日韩精品 | 国产精品日本| 欧美一区二区啪啪| 欧美中文字幕精品| 在线成人av| 欧美国产视频在线| 欧美激情一区二区三区全黄| 一本大道av伊人久久综合| 9久草视频在线视频精品| 国产精品s色| 久久精品在线播放| 女人香蕉久久**毛片精品| 亚洲国产小视频在线观看| 亚洲人成在线播放| 欧美特黄一级| 久久精品亚洲一区二区三区浴池| 久久久久国产精品一区二区| 亚洲乱码日产精品bd| 亚洲图片欧美午夜| 一区免费观看| 一二三区精品| 国一区二区在线观看| 亚洲电影在线免费观看| 欧美视频在线观看一区二区| 欧美在线一区二区| 欧美激情综合五月色丁香| 欧美一区二区视频免费观看| 久久―日本道色综合久久| 一区二区三区视频在线| 欧美一区二区三区男人的天堂| 亚洲六月丁香色婷婷综合久久| 亚洲一级片在线看| 亚洲国产精品成人综合色在线婷婷| 亚洲精品视频二区| 亚洲国产精品99久久久久久久久| 欧美激情网友自拍| 午夜国产精品影院在线观看| 久久麻豆一区二区| 亚洲欧美在线免费| 欧美二区视频| 久久夜色精品国产欧美乱极品| 欧美日韩国产精品一区| 另类欧美日韩国产在线| 国产精品久久一卡二卡| 亚洲国产一区二区a毛片| 国语自产精品视频在线看8查询8| 亚洲作爱视频| 亚洲精品亚洲人成人网| 久久成人18免费观看| 亚洲免费综合| 欧美日韩国产综合新一区| 欧美电影免费观看网站| 国产真实久久| 亚洲一区国产| 亚洲一区二区视频在线观看| 欧美v国产在线一区二区三区| 欧美一区二区三区的| 国产精品yjizz| 99国产精品99久久久久久| 亚洲品质自拍| 欧美成人国产va精品日本一级| 久久久久国产精品麻豆ai换脸| 国产精品久久久久99| 亚洲精品一区二| 夜久久久久久| 欧美日韩直播| 日韩一级欧洲| 一区二区三区你懂的| 欧美人与性动交α欧美精品济南到| 欧美成人中文| 亚洲精品日韩欧美| 你懂的视频一区二区| 亚洲第一福利在线观看| 亚洲日本欧美| 欧美日本一道本| 一区二区三区导航| 午夜精品区一区二区三| 国产精品免费一区豆花| 亚洲男人的天堂在线| 久久精品道一区二区三区| 黄色国产精品| 老色鬼精品视频在线观看播放| 欧美成人蜜桃| 一本不卡影院| 国产精品一区二区三区观看| 欧美一级艳片视频免费观看| 久久美女艺术照精彩视频福利播放| 尹人成人综合网| 欧美大片网址| 亚洲一级影院| 麻豆精品精华液| 99精品欧美一区二区蜜桃免费| 欧美日韩另类视频| 亚洲一区二区欧美日韩| 久久婷婷蜜乳一本欲蜜臀| 亚洲国内精品在线| 国产精品v欧美精品v日韩 | 欧美在线观看日本一区| 欧美激情视频一区二区三区免费| 午夜精品免费在线| 午夜天堂精品久久久久| 国产精品中文在线| 欧美在线日韩精品| 欧美激情亚洲另类| 亚洲无人区一区| 国产亚洲精品福利| 蜜臀av性久久久久蜜臀aⅴ四虎 | 久久久久久久尹人综合网亚洲| 欧美成人午夜免费视在线看片| 夜色激情一区二区| 国产夜色精品一区二区av| 欧美顶级艳妇交换群宴| 亚洲免费在线播放| 亚洲电影免费观看高清完整版在线观看 | 国产精品99久久久久久白浆小说| 国产精品视频成人| 欧美插天视频在线播放| 亚洲男人的天堂在线观看| 亚洲第一天堂av| 久久精品国产一区二区三区| 亚洲美女少妇无套啪啪呻吟| 国产伪娘ts一区| 欧美日韩亚洲成人| 麻豆免费精品视频| 午夜在线不卡| 一本一本大道香蕉久在线精品| 免费欧美日韩| 久久精品国产一区二区三区| 亚洲一区二区三区激情| 亚洲免费观看视频| 亚洲韩国日本中文字幕| 激情视频一区二区| 国产一区二区三区最好精华液|