亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

hdu1394 分治 or 線段樹

2019-11-14 09:01:47
字體:
來源:轉載
供稿:網友

     利用分治求一次逆序數,然后每次把第一個元素放到末尾,設該交換元素的值為x,設上一次求得的逆序數為y,那么此時的逆序數等于y - x + (n - x - 1),減去x是因為x作為第一個元素,其后共有x個元素小于x,移動x會導致逆序數減少x個,而加上 (n - x - 1) 是因為將x移動到末尾,其前面(n - 1)個元素中會有(n - x - 1)個元素大于x。

    此題的復雜度在于求第一次逆序數O(nlgn),后面每次移動元素求更新后的逆序數時間是O(1),因此總的復雜度為(nlgn)。

AC代碼:

#include<cstdio>#include<algorithm>#include<cstring>using namespace std;const int maxn = 5000 +5;int a[maxn], c[maxn];int solve(int l, int r){    int mid = (l + r) / 2;    if( l == r) return 0;    int ans = 0;    ans += solve(l, mid) + solve(mid + 1, r);    // Merge    int b[maxn];    int x = l, y= mid + 1;    int  k = 0;    while(x <= mid && y <= r){        if(a[x] <= a[y]){            b[k++] = a[x++];        }        else {            ans += mid + 1 - x;            b[k++] = a[y++];        }    }    while(x <= mid) b[k++] = a[x++];    while(y <= r) b[k++] = a[y++];    k = 0;    for(int i = l; i <= r; ++i) a[i] = b[k++];    return ans;}int main(){    int n;    while(scanf("%d", &n) == 1){        for(int i = 0; i < n; ++i){            scanf("%d", &a[i]);        }        memcpy(c, a, sizeof(a));        int ans = solve(0, n-1);        int x = ans;        for(int i = 0; i < n; ++i){            ans = min(ans, x + n - 1 - 2 * c[i]);            x = x + n - 1 - 2 * c[i];        }        PRintf("%d/n",ans);    }    return 0;}

線段樹也能做這個題,每個區間保存的值代表[l, r]中總出現多少元素,每次加入x元素時,查找區間[x + 2, n]即可得到該元素的加入會增加多少逆序數。

貼上線段樹代碼:

#include<cstdio>#define min(x,y) (x) < (y) ? x : yconst int maxn = 4 * 5000 + 5;int a[5000 + 5];struct node{    int L, R;    int cnt;}t[maxn];void Build(int l, int r, int cur){    t[cur].L = l, t[cur].R = r;    t[cur].cnt = 0;    if(l == r) return;    int mid = (l + r) / 2;    Build(l, mid, cur << 1);    Build(mid + 1, r, (cur << 1) + 1);}void add(int c, int cur){    int l = t[cur].L, r = t[cur].R;    t[cur].cnt++;    if(l == r) return;    int mid = (l + r) / 2;    if(c <= mid) add(c, cur << 1);    else add(c, (cur << 1) + 1);}int find1(int l, int r, int cur){ //search the Inversion (logn)    int l1 = t[cur].L, r1 = t[cur].R;    if(l == l1 && r == r1) return t[cur].cnt;    int mid = (l1 + r1) / 2;    if(r <= mid) return find1(l, r, cur << 1);    else if(l >= mid + 1) return find1(l, r, (cur << 1) + 1);    else return find1(l, mid, cur << 1) + find1(mid + 1, r, (cur << 1) + 1);}int main(){    int n;    while(scanf("%d", &n) == 1){        Build(1, n, 1);        int ans = 0;        for(int i = 0; i < n; ++i){            scanf("%d", &a[i]);            a[i]++;            add(a[i], 1);            if(a[i] + 1 <= n) ans += find1(a[i] + 1, n, 1);        }        int x = ans;        for(int i = 0; i < n; ++i){            ans = min(ans, x + n + 1 - 2 * a[i]);            x = x + n + 1 - 2 * a[i];        }        printf("%d/n",ans);    }    return 0;}如有不當之處歡迎指出!


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲最大的av网站| 成人欧美一区二区三区在线| 国产乱肥老妇国产一区二| 亚洲欧美综合v| 国产精品99久久久久久人| 伊人久久五月天| 欧美黑人狂野猛交老妇| 菠萝蜜影院一区二区免费| 久久免费高清视频| 国产精品久久久久久av下载红粉| 亚洲午夜久久久影院| 97超碰色婷婷| 在线观看日韩欧美| 欧美日韩在线视频观看| 日韩综合视频在线观看| 国产午夜精品免费一区二区三区| 亚洲精品一区久久久久久| 欧美精品免费播放| 91免费视频国产| 日韩精品免费在线| 国产精品露脸av在线| 日韩中文字幕不卡视频| 欧美日韩激情美女| 国产精品丝袜久久久久久高清| 欧美性猛交xxxxx水多| 中文字幕免费国产精品| 国产精品视频免费观看www| 欧洲成人免费aa| 国产成人福利网站| 亚洲欧洲日本专区| 亚洲精品国产品国语在线| 国产成人久久久精品一区| 亚洲精品久久久久久久久久久久久| 国产精品∨欧美精品v日韩精品| 欧美大胆在线视频| 久久露脸国产精品| 91香蕉国产在线观看| 97精品国产97久久久久久免费| 91国产一区在线| 最新69国产成人精品视频免费| 亚洲欧美日韩精品久久| 国产欧美精品在线播放| 国产精品久久久久高潮| 国产精品日韩在线| 国语自产精品视频在线看一大j8| 久久久视频精品| 国产中文字幕日韩| 国产一区二区三区毛片| 国产精品久久久| 麻豆一区二区在线观看| 日韩视频欧美视频| 国产亚洲精品久久| 亚洲欧洲av一区二区| 欧美日韩人人澡狠狠躁视频| 亚洲免费视频在线观看| 成人国产在线激情| 色狠狠av一区二区三区香蕉蜜桃| 国内精品久久久久久久久| 国产精品三级美女白浆呻吟| 精品呦交小u女在线| 热99精品里视频精品| www.日本久久久久com.| 国产欧美日韩精品丝袜高跟鞋| 亚洲欧美国产一本综合首页| 91精品国产色综合久久不卡98口| 久久久久国产精品免费网站| 伦伦影院午夜日韩欧美限制| 成人有码在线视频| 色青青草原桃花久久综合| 狠狠躁夜夜躁人人爽超碰91| 日韩av免费在线| 欧美有码在线观看| 亚洲iv一区二区三区| 成人女保姆的销魂服务| 成人xvideos免费视频| 国产一区二区视频在线观看| 久久精品国产精品| 欧美日韩免费在线观看| 国产偷亚洲偷欧美偷精品| 亚洲jizzjizz日本少妇| 国产性猛交xxxx免费看久久| 亚洲人成在线一二| 丰满岳妇乱一区二区三区| 亚洲第一中文字幕在线观看| 亚洲精品成人久久久| 欧美日韩国产专区| 久久免费国产视频| 91精品国产综合久久久久久久久| 精品av在线播放| 91在线免费观看网站| 久久理论片午夜琪琪电影网| 亚洲国产成人精品一区二区| 97在线观看免费高清| 中日韩美女免费视频网站在线观看| 一区二区三区高清国产| 日韩激情av在线免费观看| 精品五月天久久| 国产综合色香蕉精品| 国产精品96久久久久久又黄又硬| 亚洲国产天堂久久综合| 日韩在线视频网站| 久久国内精品一国内精品| 亚洲激情中文字幕| 欧美精品在线观看| 日韩大陆毛片av| 成人在线视频福利| 亚洲最新av在线| 色多多国产成人永久免费网站| 欧美日韩国产限制| 韩国一区二区电影| 国产成人在线精品| 人人爽久久涩噜噜噜网站| 18一19gay欧美视频网站| 亚洲国产欧美一区二区丝袜黑人| 国产69久久精品成人| 国产日韩在线一区| 欧美成人免费网| 亚洲91精品在线观看| 日韩福利伦理影院免费| 久久久中精品2020中文| 色婷婷av一区二区三区久久| 97超视频免费观看| 欧美午夜精品久久久久久久| 国产精品永久免费在线| 欧美视频中文字幕在线| 久久99热精品这里久久精品| 久久久精品999| 国产97色在线| 97精品一区二区视频在线观看| 91伊人影院在线播放| 成人夜晚看av| 国产精品a久久久久久| 成人精品aaaa网站| 久久久久久国产精品美女| 91av视频在线免费观看| 午夜精品久久久久久99热软件| 亚洲电影免费观看| 欧美精品日韩www.p站| 亚洲欧美日韩国产中文专区| 国产精品美女主播| 国产精品夜色7777狼人| 国产免费亚洲高清| 国产精品久久久久久久天堂| 亚洲久久久久久久久久| 日韩av网站电影| 成人黄色大片在线免费观看| 国产亚洲视频在线| 欧美麻豆久久久久久中文| 亚洲午夜久久久久久久| 97视频在线播放| 精品国产视频在线| 亚洲在线观看视频网站| 欧美天天综合色影久久精品| 伊人久久精品视频| 96精品久久久久中文字幕| 欧美成aaa人片在线观看蜜臀| 97热精品视频官网| 国产精品国产亚洲伊人久久| 久久偷看各类女兵18女厕嘘嘘| 91色在线观看| 中日韩美女免费视频网址在线观看| 免费91麻豆精品国产自产在线观看| 一区三区二区视频| 亚洲免费福利视频|