1343D - Constant Palindrome Sum
28 Jan 2021 — Tags: None
Click to show code.
using namespace std;
using ll = long long;
using vi = vector<int>;
int solve(vi a, int k)
{
int n = (int)a.size(), ans = 1e9;
vi cnt(2 * k + 2, 0), pre(2 * k + 2, 0);
for (int i = 0; i < n / 2; ++i)
{
int l = a[i], r = a[n - i - 1];
int ll = l + 1, lr = l + k;
int rl = r + 1, rr = r + k;
++cnt[l + r];
++pre[min(ll, rl)];
--pre[max(lr, rr) + 1];
}
for (int i = 1; i <= 2 * k + 1; ++i)
pre[i] += pre[i - 1];
for (int sum = 2; sum <= 2 * k; ++sum)
ans = min(ans, (pre[sum] - cnt[sum]) + (n / 2 - pre[sum]) * 2);
return ans;
}
int main(void)
{
int t;
cin >> t;
while (t--)
{
int n, k;
cin >> n >> k;
vi a(n);
for (auto &ai : a)
cin >> ai;
cout << solve(a, k) << endl;
}
return 0;
}