国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

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

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;}如有不當之處歡迎指出!


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
国产一二三区精品视频| 天堂网中文在线| 免费女人毛片视频| www.av在线播放| 免费不卡中文字幕视频| 男女羞羞视频在线观看| 国产美女被草| 在线伊人免费视频| 免费高清视频日韩| 国产一级黄色电影| 日本在线观看| 国产精品日日爱| 国产三级视频在线看| av大片在线| 国产在线高潮| 在线看黄色av| 国产视频第一区| 免费a在线看| 在线中文av| 国产一级片在线播放| 91在线看片| 国产一区二区三区四区尤物| 亚洲一本大道| 国产精品9区| 国产字幕在线看| 伊人春色在线| 国产网站免费观看| 在线天堂中文| 国产香蕉尹人视频在线| 日本aⅴ写真网站免费| 国产对白叫床清晰在线播放| 国内自拍视频在线观看| 操操操综合网| jizz在线免费观看| 影音av资源站| 国产黄色免费网| 国产精品综合久久久久| 精品国产二区三区| 国产aⅴ超薄肉色丝袜交足| 中文字幕高清av| 天天操天天是| 国产美女在线免费观看| 亚洲第一成人在线视频| 夜夜操com| 四虎成人欧美精品在永久在线| 精品麻豆一区二区三区| 国产精品白浆流出视频| 国产精品视频一区二区图片| 国产三区视频在线观看| 国产极品一区二区三区| 精品伦理一区二区| 四虎国产精品永久| 成人欧美精品久久久久影院| 高清色视频在线观看| 国产免费永久在线观看| 国产精品入口麻豆免费看| 91麻豆精品国产91久久| 国产精品bbw一区二区三区| 中文在线官网天堂| www.操操操.com| 丁香六月婷婷| 在线午夜视频| 成网站在线观看人免费| 国产黄色高清在线| 日本高清中文字幕在线| 尤物在线视频| 天海翼中文字幕| 国产视频一二三区| www.91在线播放| 国产一卡2卡3卡4卡网站免费| 伊人免费在线| 午夜视频在线| 在线天堂中文www视软件| 久草国产视频| 亚洲欧美综合乱码精品成人网| 国产精品自产拍在线观看2019| 最近久乱中文字幕| 天天插天天射| 伊人av免费在线观看| 最近中文字幕mv免费高清电影 | wwww亚洲| 国产黄a三级三级三级av在线看| аⅴ成人天堂中文在线| 国产福利免费观看| 美女被人操视频在线观看| 国产成+人+亚洲+欧美+综合| 九九热在线视频免费观看| 精灵使的剑舞无删减版在线观看| 欧美亚洲天堂| av在线第一页| 精品国产高清a毛片无毒不卡| 国内精品免费一区二区三区| 亚洲夜夜综合| 亚洲综合在线不卡| 99色在线观看| 在线āv视频| 四虎精品视频| eeuss影院在线| www.色婷婷| 97影院理论午夜| 中文天堂av| 阿v免费在线观看| 可以免费看污视频的网站| www.eeuss影院| 超碰在线97国产| 天堂在线亚洲| 国产一二三四| 国产成人精品自线拍| 国产高清在线| 亚洲国产aⅴ精品| 国产中文字幕在线| 国产一卡2卡3卡四卡网站| 天堂资源在线中文| 国产一区二区三区四区尤物| 国产你懂的在线观看| 国产丝袜在线观看视频| 91网页在线观看| 青青久在线视频免费观看| 最新中文字幕av专区| 99热免费在线观看| 久精品在线观看| 精品国产丝袜高跟鞋| 九九在线视频| 精品久久九九| 国产性网软件大全| wwww在线观看| 国产精品视频一区二区图片| 亚洲欧美日韩成人网| 国产女人在线视频| 国产欧美日韩第一页| 香蕉视频在线看| 国产图片综合| 久久国产情侣| 97在线超碰| 国产精品久久精品牛牛影视| 久久久久久91精品色婷婷| 国产第一页在线| 最新黄网在线观看| 激情丁香在线| 日本在线天堂| 91在线最新| 国产成人va亚洲电影| 丁香综合五月| 黄色片av在线| 在线播放黄色网址| 中文资源在线网| 国产不卡视频| 国产高清av| 国产亚洲精品久久久久久青梅| 青青久在线视频免费观看| 在线播放av网站| 一本久中文高清| 国产高清免费av在线| 中文字幕色视频| 久草在线资源福利| 久久久久久91精品色婷婷| а天堂8中文最新版在线官网| av片在线观看| av中文在线| 在线观看免费观看在线91| 国产成人综合亚洲欧美在| 五月婷婷导航| 国产视频中文字幕| 国产精品18久久久久网站| 国产区在线观看| 国产精品久久久久久福利| 国产色在线 com| 国产黄色免费看| 亚洲精品影视在线| 九九热视频在线观看| 成网站在线观看人免费| 99热在线免费播放| 91高清国产| 麻豆精品视频入口| 国产免费av网站| 国产激情三区| 欧美亚洲天堂| 尤物视频在线免费观看| 国产传媒在线播放| 亚洲夜夜综合| 尤物在线网址| av在线free| 综合蜜桃精品| www.综合网.com| 尤物免费看在线视频| 精品美女在线观看视频在线观看| av中文在线资源| 国产精品秘入口| 久久精品国产亚洲a∨麻豆| 午夜视频在线| 日本一级理论片在线大全| 国产丝袜在线| а√资源新版在线天堂| 国产精品入口麻豆完整版| h网站久久久| 伊人影院在线播放| 国产成人亚洲欧美电影| 国产农村av| 国产女人在线观看| 免费观看久久久久|