cf1254B1

Posted 033000-

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了cf1254B1相关的知识,希望对你有一定的参考价值。

题意简述:给出一个01数组,每次你可以选择一个x,然后让a[x]=a[x]+a[x-1] ,a[x-1]=0,or a[x]=a[x]+a[x+1],a[x+1]=0,

要求用最少的操作次数使得至少存在一个数K>1,使得K|a[x]对于数组中每一个数

题解:显然K应该是数组总和的因数,对于一个因数,我们会将数组分成好几段,每一段分别计算最小操作次数就行了

#include <bits/stdc++.h>

using namespace std;

const int maxn = 1000006;
int n;
int a[maxn];
vector <int> v;

long long cost(int p) {
    long long ret = 0;
    for (int i = 0; i < v.size(); i += p) {
        int median = v[(i + i + p - 1) / 2];
        for (int j = i; j < i + p; ++j)
            ret += abs(v[j] - median);
    }
    return ret;
}

int main(void) {
    ios_base::sync_with_stdio(0);
    cin.tie(NULL);
    cin >> n;
    for (int i = 1; i <= n; ++i) {
        cin >> a[i];
        if (a[i] == 1) v.push_back(i);
    }
    if (v.size() == 1) {
        cout << -1 << endl;
        return 0;
    }
    long long ans = 1e18;
    int tmp = v.size(), p = 2;
    while (p * p <= tmp) {
        if (tmp % p == 0) {
            ans = min(ans, cost(p));
            while (tmp % p == 0)
                tmp /= p;
        }
        ++p;
    }
    if (tmp > 1)
        ans = min(ans, cost(tmp));
    cout << ans << endl;
    return 0;
}

  

以上是关于cf1254B1的主要内容,如果未能解决你的问题,请参考以下文章

[CF1387B1] Village (Minimum) - 贪心,树形dp

如何从后台弹出片段

CF1479B Painting the Array

[CF] 839.D

ViewPager 片段重新创建,已恢复但不可见

如何使用事件侦听器来加载动画片段的循环