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

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

HDU 2688 Rotate

題目鏈接:http://acm.hdu.edu.cn/showproblem.php?pid=2688
/*
題意:
    給定一串長度為N的序列(N <= 3000000),然后是M(M<=10000)個操作,
每個操作有兩種形式:
1. Q 詢問當前序列的順序數
2. R S E (abs(E-S) <= 1000)將下標S到E的數列向左循環旋轉一次

題解:
    樹狀數組

思路:
    經典問題,首先將N個數的順序數用樹狀數組求出來,這個操作是nlogn
的,然后對于每次R操作,統計在[S+1,E]區間中比v[S]大的數和小的數的個數,
將之前的順序數 - 比它大的數 + 比它小的數,更新這個值。然后順序賦值即可。
Q操作只需要直接輸出當前順序數的值即可。
*/


#include 
<iostream>

using namespace std;

#define maxn 10001
int ans[3000001];
int n, m;

#define ll __int64

ll c[maxn];

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


void add(int pos) {
    
while(pos < maxn) {
        c[pos] 
++;
        pos 
+= lowbit(pos);
    }

}


ll sum(
int pos) {
    ll s 
= 0;
    
while(pos > 0{
        s 
+= c[pos];
        pos 
-= lowbit(pos);
    }

    
return s;
}


int main() {
    
int i;
    
while(scanf("%d"&n) != EOF) {
        
for(i = 1; i <= 10000; i++)
            c[i] 
= 0;
        ll val 
= 0;
        
for(i = 0; i < n; i++{
            scanf(
"%d"&ans[i]);
            val 
+= sum(ans[i] - 1);
            add(ans[i]);
        }

        scanf(
"%d"&m);

        
while(m--{
            
char str[10];
            scanf(
"%s", str);

            
if(str[0== 'Q'{
                printf(
"%I64d\n", val);
            }
else {
                
int s, e;
                scanf(
"%d %d"&s, &e);
                
if(s > e) {
                    
int tmp = s;
                    s 
= e;
                    e 
= tmp;
                }


                
if(s != e) {
                    
int v = ans[s];
                    
int lt = 0, bt = 0;
                    
for(i = s; i < e; i++{
                        ans[i] 
= ans[i+1];
                        
if(v < ans[i+1]) {
                            lt 
++;
                        }

                        
if(v > ans[i+1]) {
                            bt 
++;
                        }


                    }

                    ans[e] 
= v;
                    val 
= val - lt + bt;
                }

            }

        }

    }

    
return 0;
}

posted on 2011-04-11 12:19 英雄哪里出來 閱讀(2099) 評論(3)  編輯 收藏 引用 所屬分類: 樹狀數組

評論

# re: HDU 2688 Rotate  回復  更多評論   

我想問問學長
樹狀數組在這題是不是只是在求N對數的順序數時把時間復雜度
從n^2降到了nlogn

而在進行變換的時候似乎是完全模擬的
那么總的時間復雜度
還是有O(M*abs(E-R))
那么多
差不多1000W是不是?
2011-04-12 10:52 |

# re: HDU 2688 Rotate  回復  更多評論   

nlogn時間也有
6000多W???
怎么沒超時呢?
2011-04-12 10:54 |

# re: HDU 2688 Rotate  回復  更多評論   

@略
還是有O(M*abs(E-R)) 1000W
nlogn時間也有 6000多W

但這都是針對最大數據的~~大數據的組數應該不多~~
2011-04-12 11:13 | 英雄哪里出來
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧美成人一区二区三区| 亚洲精品永久免费| 亚洲欧美激情一区二区| 亚洲大胆美女视频| 一区二区亚洲精品国产| 欧美成人一区二区三区在线观看 | 久久精品99国产精品日本| 亚洲综合精品一区二区| 国产亚洲精品久久久久婷婷瑜伽 | 亚洲欧美日韩国产综合在线| 亚洲天堂网站在线观看视频| 国产一区二区你懂的| 嫩草国产精品入口| 欧美高清在线视频| 午夜精品久久久久久久久久久| 亚洲综合色婷婷| 亚洲成色777777在线观看影院| 最新亚洲视频| 国产精品久久国产愉拍| 快射av在线播放一区| 欧美精品七区| 久久久久久久综合日本| 蜜臀av性久久久久蜜臀aⅴ| 在线视频你懂得一区二区三区| 亚洲免费视频网站| 亚洲七七久久综合桃花剧情介绍| 亚洲视频一区二区在线观看| 影音先锋亚洲电影| 日韩亚洲欧美综合| 一区二区亚洲精品国产| 中文久久精品| 亚洲日本在线观看| 久久aⅴ国产紧身牛仔裤| 一本色道精品久久一区二区三区 | 午夜宅男久久久| 亚洲精品资源| 久久精品国产亚洲a| 亚洲与欧洲av电影| 蜜臀a∨国产成人精品| 久久国产精品99国产精| 欧美日韩国产探花| 欧美1区视频| 国产午夜精品久久久| 亚洲巨乳在线| 亚洲人成人一区二区三区| 欧美一区二区私人影院日本| 亚洲图片欧美午夜| 欧美高清视频在线| 女同性一区二区三区人了人一| 国产精品午夜视频| 这里只有精品视频| 中文日韩在线| 欧美日本在线看| 亚洲激情影院| 亚洲国产裸拍裸体视频在线观看乱了| 亚洲一区二区在线免费观看视频| 一本色道**综合亚洲精品蜜桃冫| 免费观看日韩| 亚洲高清久久久| 亚洲高清一区二区三区| 久热爱精品视频线路一| 老鸭窝91久久精品色噜噜导演| 国产女同一区二区| 国产精品福利在线观看| 日韩亚洲欧美一区| 亚洲天堂视频在线观看| 欧美精品偷拍| 亚洲乱码国产乱码精品精可以看 | 欧美性淫爽ww久久久久无| 亚洲美洲欧洲综合国产一区| 99亚洲一区二区| 欧美色图一区二区三区| 亚洲伦理久久| 亚洲女优在线| 国产日韩精品一区二区| 欧美影片第一页| 免费在线看一区| 亚洲区在线播放| 欧美日韩日日骚| 亚洲一区中文| 久久野战av| 亚洲三级影院| 欧美性一二三区| 久久国产精品色婷婷| 欧美**人妖| 一区二区精品在线观看| 国产精品久久久久秋霞鲁丝 | 亚洲精品无人区| 午夜精品久久久久久99热| 国产精品一区二区欧美| 久久九九全国免费精品观看| 亚洲国产精品精华液2区45| 制服丝袜激情欧洲亚洲| 国产欧美一区二区精品秋霞影院| 久久精品91久久久久久再现| 亚洲国产精选| 欧美亚洲视频在线观看| 亚洲国产mv| 欧美日韩一区二区三区在线观看免 | 制服丝袜激情欧洲亚洲| 久久天天狠狠| 亚洲午夜精品网| 韩国成人理伦片免费播放| 欧美日韩成人在线观看| 欧美一区二区视频在线观看2020 | 亚洲国产视频一区| 亚洲欧美日韩国产综合在线 | 国产一区二区三区久久久久久久久| 美女久久一区| 亚洲自拍高清| 99视频精品全国免费| 噜噜噜躁狠狠躁狠狠精品视频| 亚洲私人影院在线观看| 一区二区在线免费观看| 国产农村妇女毛片精品久久莱园子| 蜜桃精品久久久久久久免费影院| 亚洲一区二区三区四区五区午夜| 欧美成人嫩草网站| 久久国产色av| 亚洲一区在线视频| 亚洲毛片网站| 在线不卡欧美| 国产综合在线看| 国产欧美日韩精品一区 | 久久久久国产一区二区| 国产美女一区二区| 欧美三级欧美一级| 欧美激情一区二区三级高清视频| 欧美主播一区二区三区| 亚洲欧美成人网| 一区二区三区欧美激情| 99国产精品久久久久久久久久| 欧美电影专区| 欧美91视频| 欧美freesex8一10精品| 久久久久天天天天| 久久久亚洲一区| 久久久久久久久岛国免费| 欧美一区午夜精品| 欧美亚洲综合另类| 亚洲制服丝袜在线| 亚洲欧美高清| 欧美一区二区三区成人| 欧美亚洲午夜视频在线观看| 午夜久久一区| 久久精品一区二区三区四区| 欧美亚洲免费高清在线观看| 欧美一区成人| 久久精品女人| 久久综合国产精品| 能在线观看的日韩av| 免费一区视频| 亚洲人成久久| 一区二区免费在线视频| 亚洲一区二区三区午夜| 香蕉av777xxx色综合一区| 久久精品三级| 欧美va天堂va视频va在线| 欧美精品aa| 国产精品视频网址| 国内精品美女在线观看| 在线观看欧美| 亚洲精品久久久久久久久| 在线亚洲激情| 久久精品成人欧美大片古装| 久久综合九色综合网站| 亚洲精品一区二| 亚洲欧美成人网| 欧美多人爱爱视频网站| 欧美午夜片欧美片在线观看| 国产亚洲一级| 99国产一区| 久久精品国产99| 亚洲国产精品传媒在线观看| 亚洲深夜福利| 免费观看不卡av| 国产日韩精品在线播放| 亚洲精品美女在线| 欧美一进一出视频| 欧美国产在线视频| 亚洲天堂免费观看| 欧美1区2区3区| 国产农村妇女毛片精品久久莱园子| 亚洲国产福利在线| 欧美一级在线亚洲天堂| 欧美激情久久久| 午夜久久久久久久久久一区二区| 欧美jizzhd精品欧美巨大免费| 国产精品免费看久久久香蕉| 亚洲国产精品一区| 欧美一区在线视频| 亚洲精品男同| 巨胸喷奶水www久久久免费动漫| 国产精品色午夜在线观看| 亚洲精品老司机| 猫咪成人在线观看| 欧美在线亚洲一区| 欧美日韩国产欧| 亚洲日本成人| 另类图片国产|