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

            Uriel's Corner

            Research Associate @ Harvard University / Research Interests: Computer Vision, Biomedical Image Analysis, Machine Learning
            posts - 0, comments - 50, trackbacks - 0, articles - 594

            POJ 2188 Cow Laundry---求逆序數

            Posted on 2010-01-30 03:07 Uriel 閱讀(634) 評論(0)  編輯 收藏 引用 所屬分類: POJ
                跟著隊長切的題,以為可以迅速的水過去。。誰知看完暈乎暈乎的,題意都不懂。。一翻Discuss說是逆序數,完全沒想法。。想來想去怎么套上逆序數的東西。。基本上已經是湊答案了。。
                WA了幾次之后終于猜對題意了。。
                由于不一定編號要排好,只要最后對應就行,所以第一步就是改編號,其中一個改為按順序的1-N,另一個改為與之對應的編號,求其逆序數即可,我的丑陋代碼。求逆序數用mergeSort,以前做2299寫的,做模板用了~
            /*Problem: 2188  User: Uriel 
               Memory: 180K  Time: 16MS 
               Language: C++  Result: Accepted
            */
             

            #include
            <stdio.h>
            #include
            <stdlib.h>
            #include
            <algorithm>
            using namespace std;

            int b[1010],N,change,a[1010],flag[1010],c[1010];

            void merge(int p,int q,int r)
            {
                
            int i,j=0;
                
            int beginA=p,endA=q,beginB=q+1,endB=r; 
                
            while(beginA<=endA && beginB<=endB) 
                
            {
                    
            if(a[beginA]<=a[beginB]) 
                    
            {
                        b[j
            ++]=a[beginA++];
                    }
             
                   
            else 
                   
            {
                        b[j
            ++]=a[beginB++];
                        change 
            += q - beginA + 1;
                   }

                }

                
            while(beginA<=endA) 
                
            {
                    b[j
            ++]=a[beginA++];
                }

                
            while(beginB<=endB) 
                
            {
                    b[j
            ++]=a[beginB++];
                }

                
            for(i=0;i<j;i++)
                
            {
                    a[p
            +i]=b[i];
                }

            }


            void mergeSort(int first, int last)
            {
                
            int mid;
                
            if(first<last)
                
            {
                    mid
            =(first+last)/2;
                    mergeSort(first,mid);
                    mergeSort(mid
            +1,last);
                    merge(first,mid,last);
                }

            }


            int main()
            {
                
            int i,x,y;
                scanf(
            "%d",&N);
                
            for(i=0;i<N;i++)
                
            {
                    scanf(
            "%d %d",&a[i],&c[i]);
                    flag[c[i]]
            =i;
                }

                
            for(i=0;i<N;i++)
                
            {
                    a[i]
            =flag[a[i]];
                }

                change
            =0;
                mergeSort(
            0,N-1);
                printf(
            "%d\n",change);
                system(
            "PAUSE");
                
            return 0;
            }

            国产精品久久永久免费| 亚洲精品97久久中文字幕无码| 久久婷婷五月综合色奶水99啪| 久久久噜噜噜www成人网| 91久久精品无码一区二区毛片| 久久精品亚洲精品国产欧美| 免费精品久久久久久中文字幕 | 久久久久噜噜噜亚洲熟女综合| 一级做a爰片久久毛片免费陪| av国内精品久久久久影院| 开心久久婷婷综合中文字幕| 国产精品无码久久综合| 欧美色综合久久久久久| 国产精品久久久久影院色| 久久亚洲精品国产精品婷婷| 国产一久久香蕉国产线看观看| 模特私拍国产精品久久| 色综合久久天天综合| 久久66热人妻偷产精品9| 一本久道久久综合狠狠躁AV| 嫩草影院久久99| AAA级久久久精品无码片| 久久妇女高潮几次MBA| 色狠狠久久综合网| 一级做a爰片久久毛片免费陪| 国产亚洲成人久久| 一本大道加勒比久久综合| 久久超乳爆乳中文字幕| 久久妇女高潮几次MBA| 新狼窝色AV性久久久久久| 久久久久免费精品国产| 中文成人无码精品久久久不卡 | 99久久成人18免费网站| 国产精品18久久久久久vr| 国产精品天天影视久久综合网| 一本久久a久久精品vr综合| 久久久久久久97| …久久精品99久久香蕉国产| 国内精品久久久久久野外| 色综合久久精品中文字幕首页| 色综合色天天久久婷婷基地|