Codeforces 459D Pashmak and Parmida's problem(樹狀數組),codeforces459d

來源:互聯網
上載者:User

Codeforces 459D Pashmak and Parmida's problem(樹狀數組),codeforces459d

題目連結:Codeforces 459D Pashmak and Parmida's problem

題目大意:給定一個序列,定義f(l,r,x)為l≤k≤r並且ak=x的k的個數,求1≤i<j≤n的情況下,f(1,i,ai)<f(j,n,aj)的個數。

解題思路:預先處理出f(1,i,ai),f(j,n,aj)值,然後用樹狀數組維護個數。

#include <cstdio>#include <cstring>#include <algorithm>using namespace std;typedef long long ll;const int maxn = 1e6+5;struct state {    int val, pos;}sta[maxn];bool cmp (const state& a, const state& b) {    if (a.val != b.val)        return a.val < b.val;    return a.pos < b.pos;}int n, c[maxn], f[maxn];ll v[maxn];void add (int x, int val) {      while (x <= n) {          v[x] += val;          x += (x & (-x));      } } ll sum(int x) {      ll ans = 0;      while (x > 0) {          ans += v[x];          x -= (x &(-x));      }     return ans;  }ll solve () {    ll ret = 0;    memset(v, 0, sizeof(v));    for (int i = n-1; i >= 0; i--) {        ret += sum(c[i]-1);        add(f[i], 1);    }    return ret;}int main () {    scanf("%d", &n);    for (int i = 0; i < n; i++) {        scanf("%d", &sta[i].val);        sta[i].pos = i;    }    sort(sta, sta+n, cmp);    int pre = -1, cnt = 0;    for (int i = 0; i < n; i++) {        if (pre != sta[i].val) {            pre = sta[i].val;            cnt = 1;        } else            cnt++;        c[sta[i].pos] = cnt;    }    pre = -1, cnt = 0;    for (int i = n; i >= 0; i--) {        if (pre != sta[i].val) {            pre = sta[i].val;            cnt = 1;        } else            cnt++;        f[sta[i].pos] = cnt;    }    printf("%lld\n", solve());    return 0;}



聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.