首页 > 其他 > 详细

[CF1286A] Garland - dp

时间:2020-05-01 23:56:50      阅读:103      评论:0      收藏:0      [点我收藏+]

Description

有一个由 $ 1 $ - $ n $ 构成的排列,其中部分被删除(删除的元素由 $ 0 $ 代替),请用被删除的元素补全这个数列,使这个数列中相邻元素奇偶性不同的对数最少。\(n \le 100\)

Solution

\(f[i][j][0/1]\) 表示用了 \(i\) 个奇数,\(j\) 个偶数,上一位是奇数或偶数时的最小值

#include <bits/stdc++.h>
using namespace std;

#define int long long
const int N = 105;

int f[N][N][2],a[N],n;

signed main() {
    ios::sync_with_stdio(false);
    cin>>n;
    for(int i=1;i<=n;i++) cin>>a[i];
    memset(f,0x3f,sizeof f);
    f[0][0][0]=f[0][0][1]=0;
    for(int l=1;l<=n;l++) {
        for(int i=0;i<=l;i++) {
            int j=l-i;
            if(a[l]) {
                if(a[l]&1) {
                    if(i>0) f[i][j][1]=min(f[i-1][j][0]+1,f[i-1][j][1]);
                }
                else {
                    if(j>0) f[i][j][0]=min(f[i][j-1][0],f[i][j-1][1]+1);
                }
            }
            else {
                if(i>0) f[i][j][1]=min(f[i-1][j][1],f[i-1][j][0]+1);
                if(j>0) f[i][j][0]=min(f[i][j-1][0],f[i][j-1][1]+1);
            }
        }
    }
    /*for(int i=0;i<=n;i++) {
        for(int j=0;j<=n;j++) {
            cout<<f[i][j][0]<<"|"<<f[i][j][1]<<" ";
        }
        cout<<endl;
    }*/
    cout<<min(f[(n+1)/2][n/2][0],f[(n+1)/2][n/2][1]);
}

[CF1286A] Garland - dp

原文:https://www.cnblogs.com/mollnn/p/12815374.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!