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

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 閱讀(1062) 評論(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>
            日韩视频中午一区| 国产精品v片在线观看不卡| 久久精品在线播放| 久久综合九色99| 欧美成人综合一区| 国产精品xxx在线观看www| 一区二区高清在线| 久久精品日韩欧美| 亚洲高清一二三区| 亚洲激情一区二区| 午夜精品久久99蜜桃的功能介绍| 久久色在线观看| 亚洲精品无人区| 久久精品女人| 亚洲精品一区二区三区四区高清 | 国产日韩亚洲欧美| 亚洲精品久久久蜜桃| 亚洲免费av观看| 麻豆国产精品777777在线| 国产日韩精品在线播放| 欧美成人免费一级人片100| 亚洲美女中文字幕| 国产日本精品| 国产免费观看久久| 亚洲开发第一视频在线播放| 欧美国产日韩精品| 亚洲欧美在线一区| 欧美日韩亚洲免费| 亚洲国产精品va在线看黑人| 久久精品一区二区| 性久久久久久久久久久久| 欧美性视频网站| 免费不卡在线观看av| 欧美一区二区私人影院日本| 国产精品黄视频| 亚洲欧美国产精品va在线观看| 亚洲毛片在线看| 一区二区三区自拍| 久久综合久久久久88| 久久五月天婷婷| 亚洲激情综合| 欧美淫片网站| 亚洲国产成人久久综合| 亚洲在线日韩| 国产美女精品视频| 99re成人精品视频| 最近看过的日韩成人| 亚洲精品日本| 亚洲福利在线看| 久久国产视频网站| 亚洲精品资源美女情侣酒店| 久久九九精品| 久久精品人人爽| 国产精品一区一区三区| 99riav1国产精品视频| 国产精品国产三级国产a| 亚洲高清视频在线| 亚洲国产视频直播| 久久美女性网| 玖玖视频精品| 欧美人在线观看| 亚洲影院色在线观看免费| 先锋资源久久| 欧美在线亚洲在线| 免费观看在线综合| 午夜在线电影亚洲一区| 蜜臀av在线播放一区二区三区| 久久精品72免费观看| 国产日韩欧美视频在线| 亚洲欧美日韩区| 久久九九电影| 在线看片第一页欧美| 99国产精品久久久久久久成人热| 亚洲另类在线视频| 欧美性jizz18性欧美| 亚洲无限乱码一二三四麻| 精品成人国产| 男女激情久久| av不卡在线| 欧美在线高清| 欧美日韩亚洲综合| 亚洲网址在线| 久久在线精品| 99re66热这里只有精品4| 欧美日韩午夜剧场| 亚洲综合第一| 亚洲自拍电影| 国产自产精品| 亚洲一区二三| 久久综合色天天久久综合图片| 亚洲电影中文字幕| 欧美日韩亚洲国产一区| 亚洲香蕉成视频在线观看| 久久久噜噜噜久久狠狠50岁| 亚洲欧洲偷拍精品| 国产精品日韩欧美一区| 香蕉久久久久久久av网站| 国产一区二区成人| 午夜一区不卡| 亚洲国产精品综合| 91久久精品国产91性色| 欧美视频久久| 9色精品在线| 久色成人在线| 国产精品99久久久久久人| 欧美精品色网| 亚洲精品在线视频观看| 久久久久久久久伊人| 99国产精品久久久久老师| 国产真实乱子伦精品视频| 欧美日韩另类在线| 久久漫画官网| 亚洲宅男天堂在线观看无病毒| 欧美国产精品久久| 久久精品夜色噜噜亚洲aⅴ| 一二三区精品福利视频| 欧美日韩亚洲综合| 久久天堂成人| 欧美在线免费视屏| 一区二区三区免费观看| 欧美一级大片在线观看| 99热在这里有精品免费| 今天的高清视频免费播放成人| 国产精品久久久久三级| 亚洲欧美日韩专区| 日韩一级不卡| 亚洲精品麻豆| 午夜精品视频在线观看| 夜夜嗨一区二区| 亚洲国产精品一区二区尤物区| 国产午夜精品全部视频播放| 欧美视频一区二区三区四区| 欧美电影免费| 欧美ed2k| 欧美1区2区3区| 免费观看日韩| 久久综合网hezyo| 久久野战av| 老司机一区二区三区| 久久精品毛片| 久久这里只精品最新地址| 久久国产精品99精品国产| 欧美一区二区三区在线免费观看 | 久久久欧美一区二区| 欧美伊人久久久久久久久影院| 亚洲制服av| 欧美在线网址| 久久久久久久激情视频| 久久婷婷av| 欧美波霸影院| 香蕉久久一区二区不卡无毒影院| 亚洲一区二区在线看| 亚洲专区国产精品| 午夜精品影院| 久久久久网站| 欧美大片免费观看| 亚洲欧洲另类| 嫩草国产精品入口| 亚洲成人资源网| 久久精品国产久精国产一老狼| 久久精品国产综合| 欧美黑人国产人伦爽爽爽| 亚洲国产欧美不卡在线观看| 99精品欧美| 欧美一区日韩一区| 欧美电影免费| 国产精品裸体一区二区三区| 国产综合色产在线精品| 亚洲激情图片小说视频| 亚洲视频每日更新| 久久免费99精品久久久久久| 亚洲盗摄视频| 亚洲欧美日韩一区二区| 久久午夜电影网| 国产精品大片免费观看| 狠狠综合久久av一区二区老牛| 国产精品永久在线| 亚洲国产成人精品久久| 亚洲午夜精品一区二区| 中文av一区二区| 久久久精品一品道一区| 91久久精品国产91久久| 亚洲欧美三级在线| 欧美精品一级| 好吊视频一区二区三区四区 | 亚洲欧洲日产国产综合网| 中日韩视频在线观看| 久久夜色精品一区| 亚洲手机成人高清视频| 欧美jizz19hd性欧美| 国产欧美va欧美va香蕉在| 99在线视频精品| 乱中年女人伦av一区二区| 亚洲视频一二| 亚洲欧美日韩精品久久久| 欧美承认网站| 一区二区在线观看av| 欧美亚洲一级| 中文在线资源观看视频网站免费不卡| 久久天堂国产精品|