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

隨筆 - 97, 文章 - 22, 評(píng)論 - 81, 引用 - 0
數(shù)據(jù)加載中……

HDU 2836 Traversal

題目鏈接:http://acm.hdu.edu.cn/showproblem.php?pid=2836
/*
題意:
    給定N(N <= 100000)個(gè)數(shù)字ai和一個(gè)H,要求求出特殊序列的數(shù)量
,所謂特殊序列,就是相鄰兩個(gè)數(shù)字的絕對(duì)值小于等于H并且序列長(zhǎng)度
大于等于2。

解法:
樹(shù)狀數(shù)組 + 動(dòng)態(tài)規(guī)劃

思路:
     首先我們利用dp[i]表示到第i個(gè)位置能夠找到的相鄰數(shù)字之差小
于等于H的長(zhǎng)度大于等于1的序列的總和,那么有狀態(tài)轉(zhuǎn)移方程
dp[i] = sum{ dp[j], j<i, abs(a[j]-a[i]) <= H },這個(gè)做法的時(shí)間
復(fù)雜度是O(n^2),但是n很大,所以不能采用,但是我們觀察到這個(gè)轉(zhuǎn)移
方程是以求和的形式出現(xiàn),并且有一個(gè)限制條件就是abs(a[j]-a[i])<=H
,我們可以把它簡(jiǎn)寫成a[i]-H <= a[j] <= a[i]+H,那么如果我們把數(shù)
字映射到下標(biāo),并且通過(guò)二分找到a[j]的范圍,就可以輕松的通過(guò)樹(shù)狀
數(shù)組的成段求和來(lái)統(tǒng)計(jì)了。
    具體做法是:由于數(shù)字較大,我們可以先將所有數(shù)字離散化,這樣
每個(gè)數(shù)字就有一個(gè) <= n 的標(biāo)號(hào),然后這個(gè)標(biāo)號(hào)就可以對(duì)應(yīng)樹(shù)狀數(shù)組的
下標(biāo)了,每次從左往右在樹(shù)狀數(shù)組中統(tǒng)計(jì)[a[i]-H, a[i]+H]的解的數(shù)量
(注意,這里需要找到離散后對(duì)應(yīng)的數(shù)字),然后將當(dāng)前數(shù)字(離散后
的數(shù)字)插入到樹(shù)狀數(shù)組中,值即為先前找到的節(jié)的數(shù)量,循環(huán)結(jié)束,
累加和就是序列大于等于1的解的數(shù)量,然后再減去n就是最后的答案了
,這里注意是取模,并且保證答案不能為負(fù)數(shù)。
*/


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

#define maxn 100010
#define mod 9901

int n;
int val[maxn], t[maxn], c[maxn];
int tot;

int lowbit(int x) {
    
return x & (-x);
}


void add(int pos, int v) {
    
while(pos <= tot) {
        c[pos] 
+= v; 
        
if(c[pos] >= mod ) 
            c[pos] 
%= mod;
        pos 
+= lowbit(pos);
    }

}


int sum(int pos) {
    
int s = 0;
    
while(pos >= 1{
        s 
+= c[pos];
        
if(s >= mod ) 
            s 
%= mod;
        pos 
-= lowbit(pos);
    }

    
return s;
}


int Bin(int v) {
    
int l = 1;
    
int r = tot;
    
while(l <= r) {
        
int m = (l + r) >> 1;
        
if(v == t[m])
            
return m;
        
if(v > t[m])
            l 
= m + 1;
        
else
            r 
= m - 1;
    }

}


// 找到最小的大于等于它的數(shù)
int BThan(int v) {
    
int l = 1;
    
int r = tot;
    
int ans = 1;
    
while(l <= r) {
        
int m = (l + r) >> 1;
        
if(t[m] >= v) {
            r 
= m - 1;
            ans 
= m;
        }
else
            l 
= m + 1;
    }

    
return ans;
}


// 找到最大的小于等于它的數(shù)
int LThan(int v) {
    
int l = 1;
    
int r = tot;
    
int ans = tot;
    
while(l <= r) {
        
int m = (l + r) >> 1;
        
if(t[m] <= v) {
            l 
= m + 1;
            ans 
= m;
        }
else
            r 
= m - 1;
    }

    
return ans;
}


int H;

int main() {
    
int i;
    
while(scanf("%d %d"&n, &H) != EOF) {
        
for(i = 0; i < n; i++{
            scanf(
"%d"&val[i]);
            t[i
+1= val[i];
        }

        tot 
= 0;
        sort(t
+1, t+1+n);
        
for(i = 1; i <= n; i++{
            
if(i==1 || t[i] != t[i-1]) {
                t[
++tot] = t[i];
                c[tot] 
= 0;
            }

        }


        
int ans = 0;
        
for(i = 0; i < n; i++{
            
int nidx = Bin(val[i]);
            
int l = BThan(val[i] - H);
            
int r = LThan(val[i] + H);
            
int preVal = (sum(r) - sum(l-1)) % mod;
            
if(preVal < 0)
                preVal 
+= mod;
            ans 
+= preVal + 1if(ans >= mod) ans %= mod;
            add(nidx, preVal 
+ 1);
        }

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

    
return 0;
}

posted on 2011-04-06 12:38 英雄哪里出來(lái) 閱讀(1238) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 樹(shù)狀數(shù)組

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产精品成人综合色在线婷婷| 欧美日本免费一区二区三区| 亚洲精品美女免费| 久久久久久久欧美精品| 亚洲新中文字幕| 亚洲精品国产精品国自产在线 | 国产精品久久久91| 男男成人高潮片免费网站| 性刺激综合网| 亚洲一区二区不卡免费| 日韩午夜av在线| 亚洲国产欧美国产综合一区| 久久偷窥视频| 久久久精品一品道一区| 性视频1819p久久| 亚洲一区精品电影| 亚洲视频福利| 中文亚洲欧美| 亚洲图色在线| 亚洲午夜羞羞片| 亚洲视频一区在线| 亚洲视频一区二区| 亚洲一区二区三区在线| 一区二区免费在线视频| 99re6这里只有精品| 亚洲乱码久久| 一区二区三区四区五区精品| 99国产麻豆精品| 一区二区三区产品免费精品久久75 | 欧美日韩999| 欧美激情国产日韩精品一区18| 久久夜色撩人精品| 免费视频一区二区三区在线观看| 久久亚洲不卡| 欧美成人精品福利| 欧美理论在线播放| 欧美午夜精品理论片a级按摩| 欧美日韩一区二区在线| 欧美午夜精品久久久久久超碰| 欧美四级在线| 国产日韩精品在线观看| 国内一区二区三区在线视频| 国内一区二区在线视频观看| 一区国产精品| 亚洲精品九九| 亚洲一区二区在线视频| 午夜视频一区| 麻豆av福利av久久av| 欧美激情视频在线播放| 99精品热视频| 亚洲欧美色婷婷| 久久久久五月天| 欧美国产日韩一二三区| 国产精品www网站| 国产视频观看一区| 亚洲国产视频直播| 亚洲香蕉伊综合在人在线视看| 午夜久久久久| 美女网站久久| 夜夜嗨网站十八久久| 西瓜成人精品人成网站| 久久亚洲国产精品日日av夜夜| 欧美精品免费播放| 国产日韩精品一区二区浪潮av| 在线观看视频日韩| 在线亚洲自拍| 久热精品视频在线免费观看| 亚洲国产天堂久久综合网| 中文国产一区| 美女主播精品视频一二三四| 欧美手机在线| 一色屋精品视频在线观看网站| 日韩一区二区精品| 久久精品国产99国产精品| 亚洲高清在线观看| 午夜影院日韩| 欧美日韩少妇| 在线观看欧美日韩| 午夜精品久久久久久久99樱桃| 欧美成ee人免费视频| 亚洲一区二区伦理| 欧美chengren| 韩日在线一区| 亚洲免费在线看| 欧美激情一区二区三区在线视频观看| 在线综合亚洲| 欧美激情欧美狂野欧美精品 | 先锋影音一区二区三区| 欧美激情在线免费观看| 国产原创一区二区| 亚洲综合日韩| 亚洲日本中文字幕| 久久亚洲欧美| 国产亚洲二区| 小辣椒精品导航| 亚洲精品国产精品国自产观看| 久久国产综合精品| 国产伦精品一区二区三区视频孕妇 | 久久av老司机精品网站导航 | 久久久久久久久久看片| 国产精品一区二区久久久| 日韩一级大片在线| 欧美大片91| 久久av红桃一区二区小说| 国产精品日韩| 亚洲综合国产精品| 亚洲另类在线视频| 欧美高清在线播放| 亚洲黄网站黄| 欧美大片免费观看| 久久午夜精品一区二区| 激情婷婷欧美| 久久一区二区精品| 欧美主播一区二区三区美女 久久精品人| 国产精品久久久999| 亚洲午夜视频在线| 99精品久久久| 欧美日韩性生活视频| 夜夜狂射影院欧美极品| 91久久精品国产91久久性色tv| 老妇喷水一区二区三区| 亚洲电影免费在线观看| 老色鬼久久亚洲一区二区| 久久激情一区| 在线观看日韩av先锋影音电影院| 久久午夜国产精品| 久久亚洲欧美| 亚洲片在线观看| 最近看过的日韩成人| 欧美金8天国| 亚洲午夜一区| 亚洲自啪免费| 国产在线欧美| 免费欧美日韩国产三级电影| 久久亚洲色图| 99国产精品视频免费观看| 亚洲看片免费| 国产精品视频不卡| 久久嫩草精品久久久精品一| 久久精品一二三| 亚洲国产日韩在线| 亚洲精品乱码久久久久久| 欧美三级欧美一级| 西西人体一区二区| 欧美制服丝袜| 亚洲国产裸拍裸体视频在线观看乱了中文 | 欧美激情精品久久久久| 一区二区精品在线| 亚洲一区制服诱惑| 激情五月婷婷综合| 亚洲高清视频中文字幕| 欧美日韩精品伦理作品在线免费观看| 亚洲视频精品| 欧美呦呦网站| 亚洲精品精选| 亚洲影视综合| 亚洲成人在线| aa级大片欧美| 国内精品视频一区| 亚洲人成在线观看| 国产精品伦一区| 免费亚洲一区二区| 欧美日韩一区二区视频在线观看| 欧美在线999| 欧美成人免费全部观看天天性色| 亚洲桃花岛网站| 久久精品国产99国产精品| 日韩视频一区二区三区| 亚洲欧美一区二区视频| 亚洲第一福利社区| 日韩一级在线| 在线观看日韩av电影| 夜夜嗨一区二区| 亚洲第一精品夜夜躁人人爽| 这里只有精品电影| 亚洲国产影院| 午夜久久久久久久久久一区二区| 91久久视频| 欧美在线播放| 亚洲视频每日更新| 看欧美日韩国产| 欧美一区二区三区视频在线| 欧美福利电影网| 久久野战av| 国产精品日韩二区| 亚洲精品免费一二三区| 国产一区自拍视频| 亚洲私人影院| 日韩视频免费观看| 久久久最新网址| 欧美中文在线观看国产| 欧美三级午夜理伦三级中视频| 免费日韩一区二区| 国产日韩精品在线观看| 一道本一区二区| 一区二区欧美国产| 你懂的国产精品永久在线| 久久天天躁夜夜躁狠狠躁2022| 国产精品久久久久久久9999| 亚洲黑丝在线|