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

            我希望你是我獨(dú)家記憶

            一段永遠(yuǎn)封存的記憶,隨風(fēng)而去
            posts - 263, comments - 31, trackbacks - 0, articles - 3
               :: 首頁(yè) :: 新隨筆 ::  :: 聚合  :: 管理

            歸并求逆序數(shù)

            Posted on 2008-09-23 18:05 Hero 閱讀(553) 評(píng)論(2)  編輯 收藏 引用 所屬分類: 代碼如詩(shī)--ACM
             1 //5086 Accepted C++ 0.2460 s 1036 k Hero 
             2 
             3 #include <stdio.h>
             4 #include <string.h>
             5 #include <stdlib.h>
             6 
             7 const int size = 101000 ;
             8 typedef long long llong ;
             9 
            10 llong Mnum ;
            11 
            12 int data[size] ;
            13 int temp[size] ;
            14 
            15 int innum ;
            16 int inn, inm ;
            17 
            18 //先定義好data[]和temp[]數(shù)組
            19 void Merge( int a,int b,int c ) 
            20 {//將data[a--b]和data[b+1--c]歸并為有序的data[a-c]
            21 
            22     int sA = a ;  //數(shù)組1的起始位置
            23     int eA = b ;
            24     int sB = b+1 ;//數(shù)組2的起始位置
            25     int eB = c ;
            26     int    tt = a ;  //數(shù)組3的計(jì)數(shù)器
            27     while( sA<=eA && sB<=eB )
            28     {
            29         //if( data[sA] <= data[sB] )//從小到大排序
            30         if( data[sA] >= data[sB] )//從大到小排序
            31         {
            32             temp[tt++= data[sA++] ;
            33         }
            34         else
            35         {
            36             temp[tt++= data[sB++] ;
            37             Mnum += (b - sA + 1) ;//求逆序數(shù)Mnum
            38         }
            39     }
            40     while( sA <= eA ) temp[tt++= data[sA++] ;
            41     while( sB <= eB ) temp[tt++= data[sB++] ;
            42     //for( i=a; i<=c; i++ )    data[i] = temp[i] ;
            43     memcpy( data+a,temp+a,(c-a+1)*sizeof(int) ) ;
            44 }
            45 
            46 void Msort( int ms,int me )
            47 {//將data[ms--me]歸并排序?yàn)閐ata[ms--me]
            48     if( ms == me )
            49     {
            50         return ;
            51     }
            52     else
            53     {
            54         int mid = ( ms + me ) / 2 ;//一分為二
            55         Msort( ms,mid ) ;    //歸并左邊為有序
            56         Msort( mid+1,me ) ;  //歸并右邊為有序
            57         Merge( ms,mid,me ) ;//兩個(gè)有序數(shù)組合并
            58     }
            59 }//Mnum = 0 ; Msort( 1,n ) ;
            60 
            61 void input()
            62 {
            63     scanf( "%d %d"&inn, &inm ) ;
            64     int inx ; data[0= 0 ;
            65     forint i=1; i<=inn; i++ )
            66     {
            67         scanf( "%d"&inx ) ; inx = inx - inm ;
            68         data[i] = data[i-1+ inx ;
            69     }
            70 }
            71 
            72 void process()
            73 {
            74     Mnum = 0 ;
            75     Msort( 0, inn ) ;
            76 }
            77 
            78 void output()
            79 {
            80     printf( "%lld\n", Mnum ) ;
            81 }
            82 
            83 int main()
            84 {
            85     while( scanf( "%d"&innum ) != EOF )
            86     {
            87         while( innum -- )
            88         {
            89             input() ;
            90 
            91             process() ;
            92 
            93             output() ;
            94         }
            95     }
            96 
            97     return 0 ;
            98 }
            99 

            Feedback

            # re: 歸并求逆序數(shù)  回復(fù)  更多評(píng)論   

            2012-10-13 22:59 by 王玉
            Mnum += (b - sA + 1) ;//求逆序數(shù)Mnum 這句話對(duì)么 怎么感覺怪怪的 求指教

            # re: 歸并求逆序數(shù)  回復(fù)  更多評(píng)論   

            2012-10-13 23:02 by 王玉
            Mnum += eB - sB + 1 而且放在if( data[sA] >= data[sB] )這個(gè)判斷里面??
            老男人久久青草av高清| 久久久精品人妻一区二区三区蜜桃| 亚洲va久久久噜噜噜久久天堂| 99久久精品免费看国产一区二区三区| 性做久久久久久久久浪潮| 狠狠综合久久综合88亚洲| 久久超碰97人人做人人爱| 99精品久久久久久久婷婷| 亚洲欧美精品一区久久中文字幕| 一本色道久久综合亚洲精品| 99久久人妻无码精品系列蜜桃| 久久精品成人免费观看97| 99蜜桃臀久久久欧美精品网站| 久久香蕉国产线看观看乱码| 色婷婷久久久SWAG精品| 久久午夜羞羞影院免费观看| 91精品国产高清久久久久久国产嫩草 | 久久99国产一区二区三区| 91麻豆国产精品91久久久| 国产韩国精品一区二区三区久久 | 久久婷婷国产剧情内射白浆| 欧美激情精品久久久久| 99久久夜色精品国产网站| 国产福利电影一区二区三区久久久久成人精品综合 | 久久精品卫校国产小美女| 一级做a爱片久久毛片| 亚洲日韩中文无码久久| 久久综合视频网站| 色综合久久久久| 精品久久久久久无码专区不卡| 国产精品一区二区久久精品涩爱 | 久久天天躁夜夜躁狠狠| 久久青青国产| 欧美精品丝袜久久久中文字幕| 久久综合中文字幕| 久久久久四虎国产精品| 国产精品天天影视久久综合网| 久久99精品久久久久久动态图| 午夜天堂av天堂久久久| 无码人妻少妇久久中文字幕蜜桃| 久久精品国产亚洲AV久|