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

M.J的blog

algorithm,ACM-ICPC
隨筆 - 39, 文章 - 11, 評論 - 20, 引用 - 0
數據加載中……

POJ.2299 Ultra-QuickSort【樹狀數組+離散化】

一個求逆序對的題,N個數,N<=500000,問排成遞增序列需要相鄰的數交換多少次。一開始沒有仔細看題,上來就做,后來才發現數的范圍是999999999。因為最多500000個數,所以數和數之間的間隔很大,可以處理一下,使數的間隔變小,然后使用樹狀數組統計某個數前邊的比它大的數的個數。將所有的數放到一個結構體里,稱作num,并增加一個成員id,然后按num遞增排列,再另開一個數組給每個數重新編號,使數的范圍都在N以內。然后就可以很自然的用樹狀數組做了。時間500ms。據說歸并排序比這個要快。
Code:
 1 #include<iostream>
 2 #include<algorithm>
 3 #define M 500001
 4 using namespace std;
 5 int c[M],aa[M],n;                   //aa數組為排序后重新編號用
 6 struct digit
 7 {
 8     int num,id;
 9 }a[M];                              //num為數的大小
10 bool cmp(digit a,digit b){
11     return a.num<b.num;
12 }
13 int lowbit(int t){                 
14     return t&(t^(t-1));
15 }
16 int sum(int t){
17     int total=0;
18     while(t>0){
19         total+=c[t];
20         t-=lowbit(t);
21     }
22     return total;
23 }
24 void update(int t,int key){
25     while(t<=n){
26         c[t]+=key;
27         t+=lowbit(t);
28     }
29 }
30 int main()
31 {
32     int i,j;
33     long long ans;
34     while(scanf("%d",&n),n){
35         memset(c,0,sizeof(c));
36         ans=0;
37         for(i=1;i<=n;i++){
38             scanf("%d",&a[i].num);
39             a[i].id=i;
40         }
41         sort(a+1,a+n+1,cmp);
42         aa[a[1].id]=1;                                 //最小的數編號為1
43         for(i=2;i<=n;++i){
44             if(a[a[i].id].num!=a[a[i-1].id].num)      //如果前后兩個數不等,則編號為下標
45                 aa[a[i].id]=i;
46             else
47                 aa[a[i].id]=aa[a[i-1].id];            //否則編號與前一個相同
48         }
49         //for(i=1;i<=n;i++) printf("%d ",aa[i]);
50         for(i=1;i<=n;++i){
51             update(aa[i],1);
52             ans+=(sum(n)-sum(aa[i]));                 //每次累加該數前邊比它大的數的個數
53         }
54         printf("%lld\n",ans);
55     }
56 }

posted on 2010-05-03 17:24 M.J 閱讀(1052) 評論(2)  編輯 收藏 引用

評論

# re: POJ.2299 Ultra-QuickSort【樹狀數組+離散化】  回復  更多評論   

排序用sort不太妥當吧 sort是不穩定排序 如果給定的序列存在多個相同的元素會出現錯誤吧 盡管這個程序oj上能ac。
大概oj上給定的數據是互不相同的吧
2011-04-12 09:25 | 銀志圓

# re: POJ.2299 Ultra-QuickSort【樹狀數組+離散化】  回復  更多評論   

stable_sort可以實現穩定排序
2011-04-12 10:21 | 銀志圓
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产欧美日韩亚洲| 亚洲国产精品久久久久秋霞蜜臀| 欧美高清你懂得| 久久免费黄色| 亚洲视频视频在线| 欧美视频日韩视频在线观看| 亚洲视频中文| 亚洲女同性videos| 国产亚洲一本大道中文在线| 久久深夜福利免费观看| 玖玖玖免费嫩草在线影院一区| 亚洲国产精品久久久久秋霞蜜臀| 亚洲电影免费在线| 国产精品a久久久久久| 午夜宅男欧美| 久久久噜久噜久久综合| 亚洲日本黄色| 亚洲永久免费| 亚洲国产精品第一区二区| 亚洲免费观看视频| 国产一区二区三区黄| 欧美成人午夜| 国产精品xxxav免费视频| 久久久久久久久久久久久久一区| 欧美freesex8一10精品| 亚洲免费视频观看| 麻豆91精品| 欧美一级二区| 欧美成人一二三| 性色av香蕉一区二区| 久久综合电影一区| 亚洲欧美日韩一区在线观看| 久久久久久尹人网香蕉| 亚洲欧美日韩国产综合精品二区 | 亚洲精品久久久久久久久久久| 99精品国产福利在线观看免费| 国产午夜亚洲精品不卡| 日韩视频一区二区三区在线播放| 国产亚洲视频在线| 亚洲最新色图| 亚洲激情女人| 久久精品国产精品| 欧美影院久久久| 欧美—级a级欧美特级ar全黄| 久久久精品动漫| 欧美区高清在线| 久久久久久国产精品mv| 欧美日韩国产在线播放网站| 免费在线日韩av| 国产亚洲欧美一区在线观看| 亚洲先锋成人| 亚洲午夜伦理| 欧美日本一道本| 欧美不卡三区| 1024欧美极品| 久久一区中文字幕| 久久国产精品黑丝| 国产精品午夜电影| 在线视频精品一| 亚洲图片欧洲图片日韩av| 欧美成人综合| 亚洲国产导航| 亚洲欧洲精品天堂一级| 久久一区二区三区超碰国产精品| 久久精品成人| 免费成人美女女| 免费的成人av| 亚洲国产精品国自产拍av秋霞| 久久国产乱子精品免费女 | 亚洲成人原创| 久久综合综合久久综合| 欧美成人按摩| 亚洲国产另类精品专区 | 亚洲欧美日韩第一区| 性久久久久久久久久久久| 欧美视频不卡中文| 亚洲主播在线观看| 久久久噜久噜久久综合| 精品白丝av| 老司机精品久久| 亚洲激情六月丁香| 亚洲网站在线观看| 国产精品美女视频网站| 香港久久久电影| 奶水喷射视频一区| 亚洲每日在线| 国产精品视频福利| 欧美主播一区二区三区| 欧美成年人视频网站| 日韩视频一区二区在线观看| 欧美三级第一页| 欧美中文在线观看国产| 欧美国产在线观看| 中文在线一区| 国产视频精品网| 模特精品在线| 亚洲影音一区| 欧美激情2020午夜免费观看| 在线亚洲一区二区| 国产欧美日韩综合| 欧美成人免费全部观看天天性色| 亚洲精选一区二区| 久久欧美中文字幕| 亚洲视频欧洲视频| 韩国自拍一区| 国产精品theporn| 久久久91精品国产| 99re6这里只有精品视频在线观看| 欧美在线一级视频| 亚洲高清视频一区二区| 亚洲欧美日本在线| 亚洲国产精品久久91精品| 欧美日韩一区二区在线| 久久久亚洲精品一区二区三区| 亚洲日韩欧美视频一区| 久久精品最新地址| 亚洲视频在线观看网站| 在线播放视频一区| 国产精品日韩专区| 欧美精品成人91久久久久久久| 欧美一区二区视频观看视频| 亚洲精品男同| 亚洲成人资源| 亚洲国产一区二区三区a毛片 | 亚洲自啪免费| 91久久久久久| 欧美韩日一区| 久久夜色精品国产噜噜av| 午夜精品久久久久久久久 | 国产一区二区精品久久99| 欧美午夜宅男影院| 欧美黄色免费| 久久麻豆一区二区| 久久成人久久爱| 亚洲资源av| 午夜精品一区二区在线观看 | 免费人成精品欧美精品| 欧美在线观看一区二区三区| 亚洲性感美女99在线| 亚洲精品中文字| 亚洲国产第一| 亚洲国产二区| 亚洲国产精品成人久久综合一区| 激情综合久久| 亚洲第一天堂av| 亚洲成人自拍视频| 亚洲第一精品夜夜躁人人爽| 国内偷自视频区视频综合| 国产一区二区三区久久 | 欧美日韩一二区| 欧美午夜寂寞影院| 国产精品r级在线| 国产乱码精品一区二区三区av| 欧美性感一类影片在线播放| 欧美日韩中文精品| 国产农村妇女毛片精品久久麻豆 | 狠狠爱综合网| 在线看成人片| 亚洲精品一区二区在线观看| 亚洲精品一区二区三区av| 一本大道久久a久久精二百| 亚洲午夜精品久久久久久app| 亚洲午夜伦理| 久久久美女艺术照精彩视频福利播放| 久久国产精品黑丝| 欧美成人免费一级人片100| 亚洲国产一区二区三区a毛片| 亚洲精品日本| 午夜精品一区二区三区在线视| 久久精品视频va| 欧美国产日韩精品| 国产精品美女久久久浪潮软件 | 国产精品中文字幕在线观看| 国内一区二区三区在线视频| 久久一区二区三区av| 欧美国产精品中文字幕| 亚洲人体偷拍| 香蕉成人啪国产精品视频综合网| 欧美资源在线观看| 欧美国产日本韩| 国产三区精品| 亚洲欧洲在线看| 欧美一区网站| 最新国产成人在线观看| 亚洲自拍高清| 美女视频黄 久久| 国产欧美一区二区三区另类精品| 在线国产日韩| 午夜在线电影亚洲一区| 欧美激情亚洲另类| 亚洲免费影院| 欧美精品手机在线| 狠狠久久亚洲欧美| 亚洲综合好骚| 亚洲国产精品成人| 欧美一区国产一区| 欧美午夜精品久久久久久久| 在线看不卡av| 久久久久久久综合狠狠综合| 一本久道久久久|