题解:P12688 [KOI 2022 Round 1] 避开
lailai0916 · · 题解
题意简述
给定长度为
解题思路
奇偶最多相邻一次,最终序列只能是 奇数段 + 偶数段 或 偶数段 + 奇数段。
选定一种奇偶性
对于第
最终答案为
参考代码
#include <bits/stdc++.h>
using namespace std;
using ll=long long;
const int N=1000005;
int a[N];
ll calc(int n,int p)
{
ll res=0,k=0;
for(int i=1;i<=n;i++)
{
if((a[i]&1)==p)res+=i-(++k);
}
return res;
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n;
cin>>n;
for(int i=1;i<=n;i++)
{
cin>>a[i];
}
cout<<min(calc(n,0),calc(n,1))<<'\n';
return 0;
}