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

            M.J的blog

            algorithm,ACM-ICPC
            隨筆 - 39, 文章 - 11, 評(píng)論 - 20, 引用 - 0
            數(shù)據(jù)加載中……

            POJ.2481 Cows【樹狀數(shù)組】

            今天聯(lián)系樹狀數(shù)組,但是我發(fā)現(xiàn)我真的很笨,做了好幾道了還是不熟。這個(gè)題和前邊的也沒什么分別,是說每個(gè)牛有一個(gè)區(qū)間[s,e],兩個(gè)牛[s1,e1], [s2,e2],當(dāng)s1<=s2并且e1>=e2并且e1-s1>e2-s2時(shí),我們說牛1比牛2強(qiáng),給N個(gè)牛的區(qū)間,對(duì)于每個(gè)牛,輸出比這個(gè)牛強(qiáng)的牛的個(gè)數(shù)。
            還是需要預(yù)處理,先對(duì)每個(gè)牛的e進(jìn)行降序排序,e相同時(shí)對(duì)s進(jìn)行升序排列,這樣循環(huán)時(shí)可以保證后邊的牛絕對(duì)不比前邊的牛強(qiáng)。在循環(huán)時(shí),只需找出比當(dāng)前牛s小的牛的個(gè)數(shù)。如果遇到特殊情況,即兩個(gè)牛區(qū)間完全一樣,賦值就可以了。哎,加油吧~
            Code:
             1 #include<iostream>
             2 #include<algorithm>
             3 #include<map>
             4 #define MAX 100002                   
             5 using namespace std;
             6 int c[MAX],ans[MAX],n,imax;
             7 struct cow
             8 {
             9     int l,r,id;
            10 }a[MAX];                          
            11 bool cmp(cow a,cow b){                
            12     if(a.r==b.r)                          //如果兩個(gè)牛區(qū)間右邊界相同,按左邊界的升序排列
            13         return a.l<b.l;  
            14     return a.r>b.r;                       //按右邊界的降序排列
            15 }
            16 int lowbit(int t){
            17     return t&(t^(t-1));
            18 }
            19 int sum(int t){
            20     int total=0;
            21     while(t>0){
            22         total+=c[t];
            23         t-=lowbit(t);
            24     }
            25     return total;
            26 }
            27 void modify(int posi,int key){
            28     while(posi<=imax){
            29         c[posi]+=key;
            30         posi+=lowbit(posi);
            31     }
            32 }
            33 int main()
            34 {
            35     int i,j,k,n;
            36     while(scanf("%d",&n),n){
            37         memset(c,0,sizeof(c));
            38         imax=0;
            39         for(i=1;i<=n;i++){
            40             scanf("%d%d",&a[i].l,&a[i].r);
            41             a[i].id=i;                                    //每個(gè)牛有個(gè)id防止排序完順序變亂
            42             ++a[i].l; ++a[i].r;
            43             if(imax<a[i].l) imax=a[i].l;                 //用imax表示右邊界最大值,即求和時(shí)的邊界
            44         }
            45         sort(a+1,a+n+1,cmp);
            46         for(i=1;i<=n;++i){
            47             if(i==1){
            48                 ans[a[i].id]=sum(a[i].l);              //這里注意是ans[a[i].id]而不是ans[i]
            49                 modify(a[i].l,1);
            50             }
            51             else{
            52                 if(a[i].l==a[i-1].l&&a[i].r==a[i-1].r) //如果兩個(gè)牛完全相同,直接賦值
            53                     ans[a[i].id]=ans[a[i-1].id];
            54                 else
            55                     ans[a[i].id]=sum(a[i].l);         //否則找出左邊界l比這個(gè)牛小的
            56                 modify(a[i].l,1);
            57             }
            58         }
            59         for(i=1;i<n;++i)
            60             printf("%d ",ans[i]);
            61         printf("%d\n",ans[i]);
            62     }
            63 }
            64 

            posted on 2010-05-03 17:12 M.J 閱讀(92) 評(píng)論(0)  編輯 收藏 引用


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久久人妻精品无码一区 | 亚洲色欲久久久综合网东京热| 久久精品国产WWW456C0M| 亚洲国产精品成人久久蜜臀| 久久亚洲AV成人无码| 久久久无码一区二区三区| 久久久久久久亚洲Av无码| 国产精品美女久久久免费| 久久毛片一区二区| 亚洲精品国产成人99久久| 香蕉久久夜色精品国产2020| 99久久久国产精品免费无卡顿| 精品久久久久久国产牛牛app| 久久久久久久波多野结衣高潮| 青青青国产精品国产精品久久久久| 日日狠狠久久偷偷色综合0| 日韩人妻无码一区二区三区久久| 久久久黄片| 久久91精品综合国产首页| 99久久99久久久精品齐齐| 久久狠狠爱亚洲综合影院| 精品久久久久久国产免费了| 99精品久久精品| 久久久久成人精品无码中文字幕| 亚洲精品无码久久毛片| 久久强奷乱码老熟女| 国产精品99久久不卡| 久久久久久综合一区中文字幕| 国产精品一区二区久久不卡| 亚洲精品国产美女久久久| 久久天天躁夜夜躁狠狠| 久久久黄色大片| 久久精品极品盛宴观看| 最新久久免费视频| 亚洲精品tv久久久久| 综合久久久久久中文字幕亚洲国产国产综合一区首| 久久超碰97人人做人人爱| 国产午夜免费高清久久影院 | 久久精品18| 精品久久久久国产免费| 日本精品久久久久久久久免费|