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

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

HDU 3333 Turing Tree

題目鏈接:http://acm.hdu.edu.cn/showproblem.php?pid=3333

/*
題意:
    給出一個長度為N(N <= 30000)的數(shù)列,然后是一連串詢問,詢問數(shù)
<= 100000,問給定區(qū)間內(nèi)不同數(shù)字的和。

解法:
離線算法+離散化+線段樹

思路:
    乍看之下還是區(qū)間求和,但是要求不同數(shù)字的和,這題我的做法和一
般的區(qū)間詢問略有不同,采用離線算法。因為數(shù)字的范圍較大,所以首先
是對數(shù)列進行離散化,一般可以用二分或者hash,將大范圍的數(shù)字映射到
連續(xù)的區(qū)間。然后一次性讀入所有的區(qū)間(整數(shù)對),并且對整數(shù)對的右
端點進行遞增排序。這里注意,要記錄下整數(shù)對讀入的位置下標。接下來
按順序枚舉每個數(shù)字val[i],如果val[i]之前出現(xiàn)過,就將val[i]之前位
置的值刪除,然后在當前位置插入,當枚舉的位置和區(qū)間對中某個位置相
等時執(zhí)行詢問操作。枚舉完畢后一次性把答案按區(qū)間輸入的下標輸出即可
。總的復雜度是O(nlog(n))。
*/


#include 
<iostream>
#include 
<algorithm>
#include 
<vector>
using namespace std;

#define maxn 200010
#define ll __int64

int n, m;
int val[maxn];
int tmp[maxn], tmpsize;
int bin[maxn], size;
int hash[maxn];
ll ans[maxn];

struct Pair {
    
int l, r;
    
int idx;
}
;
vector 
< Pair > Pa;

bool cmp(Pair a, Pair b) {
    
return a.r < b.r;
}


void Process() {
    sort(tmp, tmp 
+ tmpsize);
    bin[ size 
= 1 ] = tmp[0];
    
for(int i = 1; i < tmpsize; i++{
        
if(tmp[i] != tmp[i-1])
            bin[ 
++size ] = tmp[i];
    }

}


int Binary(int v) {
    
int l = 1;
    
int r = size;
    
while(l <= r) {
        
int m = (l + r) >> 1;
        
if(bin[m] == v)
            
return m;
        
if(v > bin[m])
            l 
= m + 1;
        
else
            r 
= m - 1;
    }

}


struct Tree {
    ll Sum;
}
T[4*maxn];

void Build(int p, int l, int r) {
    T[p].Sum 
= 0;
    
if(l == r) {    
        
return ;
    }

    
int mid = (l + r) >> 1
    Build(p
<<1, l, mid);
    Build(p
<<1|1, mid+1, r);
}


void Insert(int p, int l, int r, int inPos, int val) {
    
if(l == inPos && inPos == r) {
        T[p].Sum 
+= val;
        
return ;
    }

    
int mid = (l + r) >> 1;
    
if(inPos <= mid) {
        Insert(p
<<1, l, mid, inPos, val);
    }
else {
        Insert(p
<<1|1, mid+1, r, inPos, val);
    }

    T[p].Sum 
= T[p<<1].Sum + T[p<<1|1].Sum;
}


ll Query(
int p, int l, int r, int a, int b) {
    
if(l == a && b == r) {
        
return T[p].Sum;
    }

    
int mid = (l + r) >> 1;
    ll v 
= 0;
    
if(b <= mid) {
        v 
+= Query(p<<1, l, mid, a, b);
    }
else if(a >= mid + 1{
        v 
+= Query(p<<1|1, mid+1, r, a, b);
    }
else {
        v 
+= Query(p<<1, l, mid, a, mid);
        v 
+= Query(p<<1|1, mid+1, r, mid+1, b);
    }

    
return v;
}


int main() {
    
int t;
    
int i, j;

    scanf(
"%d"&t);
    
while(t--{
        tmpsize 
= 0;
        
        scanf(
"%d"&n);
        
for(i = 1; i <= n; i++{
            scanf(
"%d"&val[i]);
            tmp[ tmpsize
++ ] = val[i];
        }


        Process();
        Pa.clear();
        scanf(
"%d"&m);
        
for(i = 0; i < m; i++{
            Pair pt;
            scanf(
"%d %d"&pt.l, &pt.r);
            pt.idx 
= i;
            Pa.push_back(pt);
        }

        sort(Pa.begin(), Pa.end(), cmp);
        
for(i = 1; i <= size; i++)
            hash[i] 
= 0;
        Build(
11, n);

        j 
= 0;
        
for(i = 1; i <= n; i++{
            
int idx = Binary(val[i]);
            
int prePos = hash[idx];
            
if( prePos ) {
                Insert(
11, n, prePos, -val[i]);
            }

            Insert(
11, n, i, val[i]);
            hash[idx] 
= i;

            
for(; j < m; j++{
                
if(Pa[j].r == i) {
                    ans[ Pa[j].idx ] 
= Query(11, n, Pa[j].l, Pa[j].r);
                }
else
                    
break;
            }

        }


        
for(i = 0; i < m; i++{
            printf(
"%I64d\n", ans[i]);
        }

    }

    
return 0;
}

posted on 2011-03-30 22:52 英雄哪里出來 閱讀(2584) 評論(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>
            中文有码久久| 国产亚洲va综合人人澡精品| 欧美激情第3页| 久久成人免费| 一本色道久久综合亚洲精品按摩| 欧美成人官网二区| 男人插女人欧美| 欧美在线观看www| 国产欧美视频一区二区| 99日韩精品| 亚洲美女诱惑| 亚洲乱码日产精品bd| 亚洲人午夜精品免费| 久久国产精品99精品国产| 亚洲图片在线| 欧美麻豆久久久久久中文| 亚洲国产成人在线播放| 亚洲天堂网在线观看| 亚洲欧美影院| 在线观看日韩www视频免费| 久久久久看片| 欧美第一黄色网| 一二美女精品欧洲| 久久久精品欧美丰满| 亚洲第一福利社区| 欧美亚洲视频在线看网址| 久久亚洲综合色| 亚洲欧美日本国产有色| 玖玖在线精品| 性欧美大战久久久久久久久| 亚洲一区国产| 亚洲欧洲在线一区| 久久精品国产久精国产爱| 国产精品裸体一区二区三区| 午夜精品久久久久久久| 久久av在线| 中文网丁香综合网| 亚洲国产精品久久久| 欧美一区二区黄色| 国产精品一区二区三区成人| 这里只有精品视频| 亚洲在线播放| 91久久精品美女| 国产精品二区二区三区| 久久久久久高潮国产精品视| 欧美 日韩 国产一区二区在线视频| 亚洲欧美日韩在线高清直播| 久久精品欧美日韩| 9色精品在线| 久久乐国产精品| 亚洲欧美成人| 欧美韩日一区| 国产精品外国| 久久午夜精品| 午夜欧美理论片| 韩国欧美一区| 一二三四社区欧美黄| 国产日韩视频一区二区三区| 欧美激情中文字幕一区二区| 亚洲美女视频在线观看| 亚洲国产精品999| 欧美小视频在线| 久久午夜国产精品| 午夜精品一区二区三区在线播放 | 狂野欧美激情性xxxx欧美| 久久国产精品久久w女人spa| 久久九九久久九九| 午夜视频在线观看一区二区三区 | 久久亚洲二区| 欧美二区不卡| 欧美日韩理论| 亚洲第一页中文字幕| 国产日韩欧美综合| 亚洲免费一级电影| 亚洲三级电影在线观看| 久久精品在线| 久久久久国产精品一区| 国产精品日本| 性做久久久久久| 国产精品每日更新| 一区二区三区你懂的| 欧美日韩精品福利| 亚洲第一色中文字幕| 亚洲在线观看| 国产性天天综合网| 亚洲激情女人| 欧美福利影院| 精品电影在线观看| 国产精品久久久久久五月尺| 久久se精品一区二区| 久久久免费精品| 亚洲国产精品一区在线观看不卡| 亚洲永久精品大片| 国产精品一区二区久久精品| 亚洲一区二区精品视频| 欧美精品综合| 亚洲图片欧美一区| 免费观看在线综合| 亚洲高清资源| 国产精品久久夜| 欧美国产日本韩| 在线视频欧美一区| 亚洲第一级黄色片| 国产欧美在线看| 国产精品v一区二区三区| 亚洲综合精品| 久久精品亚洲| 在线视频欧美日韩| 亚洲精品免费在线| 狠狠色丁香婷婷综合影院| 久久不射电影网| 日韩视频在线免费| 极品少妇一区二区三区精品视频| 久久精品一区二区| 欧美一区二区三区婷婷月色| 最近中文字幕日韩精品| 久久精品国产第一区二区三区| 久久香蕉国产线看观看av| 一区二区高清视频| 国产亚洲精品高潮| 国产精品大片免费观看| 国产午夜一区二区三区| 猛男gaygay欧美视频| 久久亚洲一区二区三区四区| 亚洲精品久久嫩草网站秘色| 久久精品国产免费| 久久久国产视频91| 久久精品动漫| 国产亚洲高清视频| 国产精品视频你懂的| 亚洲一区图片| 一区二区三区高清| 亚洲午夜视频在线观看| 亚洲色图在线视频| 亚洲私人影院在线观看| 欧美人成免费网站| 欧美日韩一区二区三区在线| 亚洲精品中文字幕在线| 亚洲毛片av| 欧美日韩一卡二卡| 亚洲天堂av图片| 午夜精品视频在线观看一区二区| 国产精品女人毛片| 激情综合激情| 亚洲一区久久久| 国产欧美精品一区二区色综合| 亚洲欧美日韩国产综合| 欧美在线亚洲一区| 国产精品久久久对白| 亚洲盗摄视频| 欧美日韩少妇| 久久精品论坛| 亚洲欧美一区二区精品久久久| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 国产欧美日韩一区二区三区在线观看| 国产一区久久久| 欧美二区在线播放| 免费不卡在线观看| 日韩亚洲精品在线| 欧美日本一区二区高清播放视频| 欧美午夜精品理论片a级按摩| 一区二区三区久久网| 久久aⅴ国产欧美74aaa| 久久久夜夜夜| 亚洲一区久久| 91久久精品日日躁夜夜躁欧美| 亚洲免费视频中文字幕| 亚洲国产欧美精品| 久久久亚洲精品一区二区三区| 亚洲网址在线| 午夜视频在线观看一区| 国产精品第一区| 欧美日韩亚洲网| 亚洲一区3d动漫同人无遮挡| 一区二区三区 在线观看视频 | 亚洲精选视频在线| 欧美日韩日日夜夜| 一区二区三区免费观看| 亚洲第一精品电影| 欧美三级第一页| 欲香欲色天天天综合和网| 亚洲国产成人porn| 国产自产精品| 夜夜嗨av一区二区三区网站四季av| 久久激情五月婷婷| 欧美国产高清| 欧美中文字幕不卡| 狂野欧美激情性xxxx| 午夜精品美女久久久久av福利| 久久天堂精品| 最新日韩精品| 久久成人18免费观看| 99国产精品视频免费观看| 亚洲欧美日韩电影| 亚洲在线视频观看| 欧美精品久久久久久久久久| 国产精品久久午夜夜伦鲁鲁| 亚洲第一在线视频| 一区二区高清在线观看| 男女精品网站|