2020 camp-day-e

题解

暴力就行(如果n 3000,那就要优化成 n^2

#include <cstdio>

#define RE register
#define FOR(i,a,b) for(RE int i=a;i<=b;++i)
#define ROF(i,a,b) for(RE int i=a;i>=b;--i)
#define sc(n) scanf("%d",&n)

using namespace std;

int m, n;
int a[305], b[5], e[6];
int tex[301][301];
long long ans;

int main()
{
    sc(n);
    FOR(i, 1, n)
    {
        FOR(j, 1, n)tex[j][i] = tex[j][i - 1];
        sc(a[i]); tex[a[i]][i] += 1;
    }
    FOR(i, 1, 4)
    {
        sc(b[i]);
        FOR(j, 1, i - 1)
            if (b[i] == b[j])
                if (j == 1)e[i - 2] = 1;
                else if (j == 2)e[i] = 1;
                else e[5] = 1;
    }
    FOR(i, 1, n - 3)
        FOR(j, i + 1, n - 2)
        {
            if (e[0] && a[i] != a[j])continue;
            if (!e[0] && a[i] == a[j])continue;
            FOR(x, j + 1, n - 1)
                if ((e[1] && a[i] != a[x]) || (!e[1] && a[i] == a[x]))continue;
                else if ((e[3] && a[j] != a[x]) || (!e[3] && a[j] == a[x]))continue;
                else if (e[2])ans += tex[a[i]][n] - tex[a[i]][x];
                else if (e[4])ans += tex[a[j]][n] - tex[a[j]][x];
                else if (e[5]) ans += tex[a[x]][n] - tex[a[x]][x];
                else ans += n - x - tex[a[i]][n] + tex[a[i]][x] - (!e[0]) * (tex[a[j]][n] - tex[a[j]][x]) - (!e[1] && !e[3]) * (tex[a[x]][n] - tex[a[x]][x]);
        }
    printf("%lld", ans);
    return 0;
}

  

posted @ 2020-01-16 22:11  洛绫璃  阅读(125)  评论(0编辑  收藏  举报