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

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 閱讀(1059) 評論(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 | 銀志圓

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            午夜精品久久久久久久| 国产欧美精品在线| 一区二区欧美国产| 在线中文字幕日韩| 亚洲午夜精品视频| 亚洲欧美一区二区三区极速播放 | 亚洲国产精品成人久久综合一区| 久久av一区二区三区| 亚洲国产精品悠悠久久琪琪| 亚洲国产中文字幕在线观看| a91a精品视频在线观看| 亚洲一区二区三区成人在线视频精品 | 欧美在线视频一区二区三区| 久久久久久久国产| 亚洲精品国产精品乱码不99按摩 | 中日韩在线视频| 久久精品一区中文字幕| 欧美日韩a区| 国产日韩专区| 一本久久综合| 久久综合伊人| 在线一区免费观看| 欧美bbbxxxxx| 国产有码一区二区| 在线视频欧美一区| 欧美成人精品三级在线观看| 一个人看的www久久| 久久永久免费| 国产日韩精品入口| 一本一本久久a久久精品牛牛影视| 久久精品国产99精品国产亚洲性色| 欧美激情视频免费观看| 亚洲欧美成人一区二区在线电影| 麻豆成人综合网| 国产农村妇女毛片精品久久麻豆| 亚洲精品乱码久久久久久按摩观| 久久精品国产视频| 亚洲视频碰碰| 欧美日韩一区二区三区视频| 91久久精品www人人做人人爽| 欧美综合国产| 亚洲女同性videos| 国产精品二区在线| 中文亚洲欧美| 日韩一区二区福利| 欧美激情1区| 亚洲每日在线| 91久久国产精品91久久性色| 久久久久久久一区二区| 国产一区二区三区丝袜 | 亚洲三级视频| 欧美国产亚洲另类动漫| 久久久精品欧美丰满| 国产日韩欧美在线播放不卡| 亚洲欧美激情视频| 亚洲视频一二区| 国产精品永久在线| 欧美中文日韩| 欧美一区二区三区视频免费播放| 国产一区二区欧美日韩| 久久女同互慰一区二区三区| 亚洲永久免费av| 国产精品一区二区视频| 欧美在线一级va免费观看| 亚洲欧美国内爽妇网| 国产精品国产三级国产专播精品人| 亚洲一二三四久久| 亚洲欧美大片| 伊人精品成人久久综合软件| 另类国产ts人妖高潮视频| 久久综合网络一区二区| 亚洲精品国产拍免费91在线| 亚洲精品美女在线| 国产精品推荐精品| 久久人人爽人人爽| 女女同性精品视频| 在线一区二区三区做爰视频网站 | 欧美日韩精品伦理作品在线免费观看| 亚洲欧洲三级电影| 日韩亚洲精品电影| 国产嫩草影院久久久久| 久久欧美中文字幕| 欧美人与禽性xxxxx杂性| 亚洲一区亚洲| 久久久国产午夜精品| aa成人免费视频| 亚洲在线网站| 亚洲国产一区二区三区在线播| 亚洲人成网站在线观看播放| 国产精品视频99| 欧美激情亚洲国产| 国产欧美一二三区| 亚洲国产日韩在线| 国产喷白浆一区二区三区| 欧美激情精品久久久久久免费印度 | aa级大片欧美三级| 欧美一区二区在线免费观看| 亚洲区一区二区三区| 亚洲一区三区电影在线观看| 亚洲国产精品一区| 午夜精彩国产免费不卡不顿大片| 亚洲精品乱码| 久久黄金**| 亚洲欧美另类中文字幕| 欧美插天视频在线播放| 久久九九全国免费精品观看| 欧美精品xxxxbbbb| 久久综合综合久久综合| 欧美视频中文字幕在线| 欧美成人精品1314www| 国产精品一区久久| 日韩天堂在线观看| 91久久夜色精品国产九色| 欧美一区二区三区日韩视频| 日韩亚洲不卡在线| 在线成人亚洲| 亚洲影院污污.| 夜夜狂射影院欧美极品| 久久久久高清| 久久国产66| 国产精品视频九色porn| 日韩视频中文| 99av国产精品欲麻豆| 久久亚洲精品伦理| 久久久五月婷婷| 国产日韩欧美中文在线播放| 制服丝袜激情欧洲亚洲| 国产精品99久久久久久久久久久久| 久久综合免费视频影院| 男女视频一区二区| 亚洲国产精品一区制服丝袜| 久久久久www| 老牛影视一区二区三区| 伊人精品在线| 老司机精品视频网站| 免费在线亚洲| 亚洲精品久久久久久下一站| 欧美电影免费观看网站| 91久久国产综合久久| 在线视频中文亚洲| 国产精品成人在线| 亚洲一区在线免费| 久久狠狠婷婷| 在线日韩av片| 欧美精品一区二区三区很污很色的| 亚洲欧洲精品一区二区三区波多野1战4 | 尤物yw午夜国产精品视频| 久久久最新网址| 欧美激情成人在线| 99视频超级精品| 国产精品久久久久久久久久ktv| 亚洲一区二区少妇| 久久久免费观看视频| 亚洲国产精品va在线看黑人动漫| 欧美成人福利视频| 亚洲深夜福利在线| 久久夜色精品国产欧美乱| 亚洲福利av| 欧美午夜三级| 久久久国产精品一区二区三区| 欧美国产综合| 午夜视频一区| 亚洲黄色在线| 欧美午夜剧场| 久久久中精品2020中文| 亚洲精品少妇| 久久最新视频| 亚洲欧美日韩国产一区二区三区| 国产一区二区三区免费在线观看 | 久久精品卡一| 最新成人av在线| 国产日韩欧美亚洲| 欧美精品一区二区三区蜜桃 | 欧美制服第一页| av成人免费观看| 老司机午夜精品| 亚洲一区二区三区成人在线视频精品| 久久精品亚洲一区| 一本色道久久88精品综合| 国产日韩免费| 欧美日韩国产成人在线91| 欧美一区二区三区四区夜夜大片 | 亚洲日韩欧美视频| 国产亚洲激情| 欧美性大战久久久久久久蜜臀| 久久久久久九九九九| 一本色道久久综合亚洲精品婷婷 | 国产日韩综合一区二区性色av| 欧美高清在线观看| 久久国产精品久久w女人spa| av成人老司机| 91久久精品美女高潮| 另类图片国产| 久久免费黄色| 久久久精品动漫| 欧美中文在线视频| 亚洲欧洲99久久| 亚洲男人的天堂在线| 亚洲一区二区黄| 亚洲一级特黄|