麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

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

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美日本一 | 久草在线精品观看 | 欧美成人免费在线视频 | free japan xxxxhdsex69| 午夜视频在线 | 久久国产精品小视频 | 亚洲午夜精品视频 | 中国精品久久 | 青青草在线免费观看 | 18一20岁一级毛片 | 欧美性生活久久久 | 一级色毛片| 午夜视频在线免费观看 | 成人性生活视频在线播放 | 欧美一级在线免费 | 精品国产一区二区三区四区在线 | 免费观看视频网站 | av在线直播观看 | 天堂成人国产精品一区 | 久久在草| 色av成人天堂桃色av | 欧美女人天堂 | 黄色av片在线观看 | 国产精品久久久久久久亚洲按摩 | 久久综合精品视频 | 日本视频在线播放 | 少妇的肉体的满足毛片 | 亚洲四播房 | 精品久久久久99 | 免费一级毛片在线播放不收费 | 中国av一级片 | 日本中文字幕网址 | 欧美一区二区三区久久精品视 | 亚洲日色 | 久久里面有精品 | 日韩黄色免费观看 | 成人三级电影在线 | 日本在线国产 | 午夜精品成人一区二区 | 久色乳综合思思在线视频 | 色屁屁xxxxⅹ在线视频 |