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

隨筆 - 97, 文章 - 22, 評論 - 81, 引用 - 0
數據加載中……

ZJU 3349 Special Subsequence

題目鏈接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3349

/*
題意:
    給定一個d(0 <= d <= 10^8)和(N <= 10^5)的數列,求最長的特殊子序列,
所謂特殊子序列就是相鄰元素之間的絕對值之差小于等于d。

解法:
動態規劃+線段樹

思路:
    這題又是一個動態規劃,狀態轉移方程很容易想到:
    dp[ val[i] ] = 1 + max( dp[ val[i] - d ]  dp[ val[i] + d ] )
dp[j] 表示以j為止的最長特殊子序列的值,這樣就可以維護一個區間,每次
查詢和當前數絕對值差小于等于d的數組成的區間,將最大值+1更新到當前數
對應的位置上,利用線段樹每次更新和查詢都是log(n)。
*/


#include 
<iostream>
#include 
<cstdio>
#include 
<cstring>
using namespace std;

#define maxn 600010

int n, d;
int val[maxn];

struct Tree {
    
int Max;
    
int son[2];

    
void clear() {
        son[
0= son[1= -1;
        Max 
= 0;
    }

}
T[maxn*4];
int tot;

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

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


void Query(int root, int nx, int ny, int l, int r, int& ans) {
    
if(nx > r || ny < l || root == -1 || T[root].Max <= ans)
        
return ;
    
if(nx <= l && r <= ny) {
        ans 
= Max(ans, T[root].Max);
        
return ;
    }

    
int mid = (l + r) >> 1;
    Query(T[root].son[
0], nx, ny, l, mid, ans);
    Query(T[root].son[
1], nx, ny, mid+1, r, ans);
}


void Insert(int& root, int nPos, int l, int r, int val) {
    
if(nPos < l || nPos > r)
        
return ;
    
if(root == -1{
        root 
= tot++;
        T[root].clear();
    }

    T[root].Max 
= Max(val, T[root].Max);

    
if(l == nPos && nPos == r) {
        
return ;
    }


    
int mid = (l + r) >> 1;
    Insert(T[root].son[
0], nPos, l, mid, val);
    Insert(T[root].son[
1], nPos, mid+1, r, val);
}


int main() {
    
int i;
    
int MMin, MMax;
    
while(scanf("%d %d"&n, &d) != EOF) {
        
for(i = 0; i < n; i++{
            scanf(
"%d"&val[i]);
            
if(i) {
                MMin 
= Min(MMin, val[i]);
                MMax 
= Max(MMax, val[i]);
            }
else {
                MMin 
= val[i];
                MMax 
= val[i];
            }

        }

        tot 
= 0;
        
int root = -1;
        
int ans = 1;

        
for(i = 0; i < n; i++{
            
int l = (val[i] - d) < MMin ? MMin : (val[i] - d);
            
int r = (val[i] + d) > MMax ? MMax : (val[i] + d);
            
int MM = 0;
            Query(root, l, r, MMin, MMax, MM);
            Insert(root, val[i], MMin, MMax, MM 
+ 1);
            
if(MM + 1 > ans)
                ans 
= MM + 1;
        }


        printf(
"%d\n", ans);
    }

    
return 0;
}

posted on 2011-03-31 17:39 英雄哪里出來 閱讀(1084) 評論(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>
            亚洲国产精品精华液网站| 尤物精品在线| 久久久www| 国产精品日韩欧美| 欧美在线观看视频在线| 国产精品日韩精品欧美在线| 亚洲一区尤物| 欧美中文在线视频| 欧美伦理在线观看| 99视频超级精品| 亚洲欧美激情在线视频| 麻豆国产精品va在线观看不卡| 欧美3dxxxxhd| 亚洲午夜久久久久久久久电影院| 欧美三区免费完整视频在线观看| 狂野欧美一区| 国产精品男人爽免费视频1| 午夜精品在线| 亚洲国产成人久久综合一区| 国产女精品视频网站免费| 欧美主播一区二区三区美女 久久精品人 | 久久久五月婷婷| 亚洲资源av| 黄色成人在线免费| 亚洲欧美另类综合偷拍| 亚洲午夜免费福利视频| 精品1区2区| 久久久精品视频成人| 99这里有精品| 欧美不卡视频一区| 亚洲国产精品va在看黑人| 欧美视频一区| 亚洲精品免费网站| 欧美一区二区三区四区在线观看地址 | 久久综合激情| 一区二区激情视频| 欧美精品乱码久久久久久按摩 | av成人免费在线观看| 亚洲视频精选| 在线视频一区观看| 在线观看视频日韩| 久久一区二区三区四区| 欧美激情欧美狂野欧美精品| 欧美一区二区三区在线| 国产一区二区三区观看| 欧美日韩成人综合| 久久夜色精品国产噜噜av| 亚洲大片在线观看| 亚洲精品一级| 欧美色网在线| 欧美黑人在线观看| 99亚洲视频| 日韩亚洲不卡在线| 亚洲精品免费看| 午夜精品久久| 国产小视频国产精品| 国产精品毛片a∨一区二区三区|国| 免费永久网站黄欧美| 久久精品一区蜜桃臀影院| 亚洲电影av| 毛片精品免费在线观看| 久久婷婷久久一区二区三区| 亚洲毛片av在线| 国产日韩精品一区| 国产精品专区h在线观看| 国产精品久久久久高潮| 欧美性理论片在线观看片免费| 欧美日韩免费在线视频| 欧美日韩在线不卡| 国产精品免费电影| 欧美风情在线观看| 欧美国产免费| 欧美网站在线| 久久婷婷国产综合精品青草| 久久免费精品日本久久中文字幕| 久久久久久久久久久成人| 久久免费午夜影院| 欧美激情第六页| 久久久噜噜噜久噜久久| 女人香蕉久久**毛片精品| 欧美片网站免费| 欧美视频中文字幕| 久久亚洲精品一区二区| 欧美精品一区二区三区蜜臀| 久久激情久久| 欧美成人午夜激情在线| 欧美一区二区在线免费播放| 久久久蜜桃一区二区人| 欧美理论片在线观看| 国产精品永久免费观看| 亚洲人体1000| 性做久久久久久| 久久亚洲综合网| 亚洲国产91色在线| 美女啪啪无遮挡免费久久网站| 欧美国产高潮xxxx1819| 久久久精品欧美丰满| 亚洲香蕉伊综合在人在线视看| 久久国产精品久久久| 欧美激情久久久久久| 麻豆91精品91久久久的内涵| 久久久之久亚州精品露出| 亚洲精品永久免费| 久久国产一区二区| 欧美性一区二区| 国产精品chinese| 亚洲国产精品一区制服丝袜| 亚洲自拍高清| 午夜精品视频一区| 亚洲欧美日韩一区二区| 亚洲国产精品成人久久综合一区| 亚洲小视频在线| 亚洲女同精品视频| 欧美日韩久久精品| 亚洲国产成人午夜在线一区| 亚洲国产精品999| 欧美一区二区三区在线| 久久久国产视频91| 国产精品99久久久久久久vr | 久久精品最新地址| 可以看av的网站久久看| 国产喷白浆一区二区三区| 国产精品三级视频| 一区二区三区导航| 亚洲国产精品久久精品怡红院| 久久成人在线| 可以免费看不卡的av网站| 欧美乱大交xxxxx| 国产精品久久久一区麻豆最新章节 | 亚洲国产一区二区三区在线播 | 欧美黄色视屏| 国产精品久久久久久久久久久久久 | 欧美在线一二三| 亚洲国产精品久久| 欧美99在线视频观看| 亚洲电影免费观看高清完整版| 亚洲毛片在线看| 欧美激情视频一区二区三区不卡| 久久影院午夜论| 欧美午夜精品久久久久久浪潮| 国产精品麻豆va在线播放| 亚洲欧美日韩网| 亚洲欧美文学| 欧美激情在线观看| 一本色道综合亚洲| 在线综合亚洲欧美在线视频| 欧美性做爰猛烈叫床潮| 亚洲欧美99| 亚洲国产欧美一区| 欧美午夜精品久久久| 欧美在线视频免费| 欧美一级专区| 在线精品高清中文字幕| 亚洲欧美日韩国产另类专区| 欧美福利一区二区| 欧美精品在线观看播放| 极品少妇一区二区三区精品视频| 久久亚洲二区| 亚洲一区二区在线播放| 欧美欧美天天天天操| 亚洲欧美日韩一区在线| 欧美一区在线看| 亚洲国产cao| 久久久欧美精品sm网站| 欧美va天堂va视频va在线| 黄色亚洲网站| 午夜日韩电影| 亚洲精品一区二区三区在线观看| 欧美午夜精品理论片a级按摩 | 99精品国产热久久91蜜凸| 久久婷婷国产综合尤物精品 | 久久久xxx| 亚洲一区国产一区| 欧美色欧美亚洲高清在线视频| 最近中文字幕日韩精品 | 久久久亚洲综合| 亚洲欧美日韩一区二区在线| 精品91久久久久| 亚洲色在线视频| 最新中文字幕一区二区三区| 欧美18av| 欧美激情欧美激情在线五月| 久久国产66| 欧美日韩国产综合视频在线| 久久综合色播五月| 猫咪成人在线观看| 一本久久综合亚洲鲁鲁五月天| 国产在线视频欧美一区二区三区| 看片网站欧美日韩| 国产精品二区在线| 中日韩高清电影网| 久久免费精品视频| 亚欧成人精品| 久久成人在线| 韩国v欧美v日本v亚洲v | 亚洲综合视频一区| 亚洲欧洲视频在线| 久久精品视频播放| 在线免费观看视频一区| 亚洲高清二区|