标签:return Garland int dfs else bj dp
参考:Codeforces Round #612 (Div. 2) A~E2 题解
试了试暴力的方法,感觉不大行,所以转战dp
总共有四个状态\(dp[x][i][j][bj]\),表示还有 i 个奇数,j 个偶数可以使用,x~n 位置的复杂度之和的最小值,且位置 x-1 的状态为 bj(1为奇,0为偶)
用dfs进行记忆化搜索,得到最优结果。
代码:
// Created by CAD on 2020/1/7.
#include <bits/stdc++.h>
#define inf 0x3f3f3f3f
#define mst(name, value) memset(name,value,sizeof(name))
using namespace std;
int p[105];
const int maxn=105;
int dp[maxn][maxn][maxn][3];
int n;
int dfs(int x,int i,int j,int bj)
{
if(x==n+1) return 0;
if(~dp[x][i][j][bj]) return dp[x][i][j][bj];
dp[x][i][j][bj]=0;
if(p[x])
{
if((p[x]&1)==bj||bj==2)
return dp[x][i][j][bj]=dfs(x+1,i,j,p[x]&1);
else return dp[x][i][j][bj]=dfs(x+1,i,j,p[x]&1)+1;
}
else
{
int a=inf,b=inf;
if(bj==2)
{
if(i>0) a=dfs(x+1,i-1,j,1);
if(j>0) b=dfs(x+1,i,j-1,0);
}
else if(bj==1)
{
if(i>0) a=dfs(x+1,i-1,j,1);
if(j>0) b=dfs(x+1,i,j-1,0)+1;
}
else
{
if(i>0) a=dfs(x+1,i-1,j,1)+1;
if(j>0) b=dfs(x+1,i,j-1,0);
}
return dp[x][i][j][bj]+=min(a,b);
}
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cin>>n;
int odd=n/2+n%2,even=n/2;
for(int i=1;i<=n;++i)
{
cin>>p[i];
if(p[i])
{
if(p[i]&1) odd--;
else even--;
}
}
mst(dp,-1);
cout<<dfs(1,odd,even,2)<<endl;
return 0;
}
标签:return,Garland,int,dfs,else,bj,dp 来源: https://www.cnblogs.com/CADCADCAD/p/12168896.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。