updata on 2020.3.19

往博客园搬的时候看了看自己以前写的blog

其实没多久,才两个多月,感觉自己之前写的东西好罗嗦啊。。

但也是最近写的blog才开始多起来

当然现在也没好到哪去。。。

CF1286A题解

整理博客的时候改了一下分类标签,重新审核一下

dp

觉得这题作为一个C比div2的B要简单点吧,算是找回点dp的信心。。。

首先可以想到,只需关心每个数的奇偶,具体是几不用记录

所以\(0\)表示偶数,\(1\)表示奇数,\(-1\)表示不确定,存在\(a[]\)中

\(num[0/1]\)表示一共有几个偶/奇数需要填

状态:

\(f[i][o][j][0/1]\): 考虑前\(i\)位,还剩\(o\)个偶数能用,剩\(j\)个奇数能用,第\(i\)位填的是偶数/奇数

初始:

先都设为极大值

  • 第一位填好了:\(f[1][num[0]][num[1]][a[1]]=0\)
  • 第一位需要自己填: \(f[1][num[0]-1][num[1]][0]=f[1][num[0]][num[1]-1][1]=0\),要判断\(num[0]\)和\(num[1]\)是否大于0

转移:

  • \(i\)位填好了:

    直接判断与前一位是否相等,不相等就加一

    \(f[i][o][j][a[i]]=\min(f[i][o][j][a[i]],f[i-1][o][j][1]+(a[i] \neq 1))\)

    \(f[i][o][j][a[i]]=\min(f[i][o][j][a[i]],f[i-1][o][j][0]+(a[i] \neq 0))\)
  • \(i\)位需要自己填:

    分别处理\(i\)位是偶数/奇数,在对应\(i-1\)位是偶数/奇数,共四种。

    容易想出\(i\)位是偶数/奇数时,被转移的状态分别应该\(o+1\)/\(j+1\)(因为记录的是可以可以填进去的偶数/奇数还剩几个,用了一个,当然要从剩余数多一个的状态转移而来)

    \(f[i][o][j][1]=\min(f[i][o][j][1],f[i-1][o][j+1][1])\)

    \(f[i][o][j][1]=\min(f[i][o][j][1],f[i-1][o][j+1][0]+1)\)

    \(f[i][o][j][0]=\min(f[i][o][j][0],f[i-1][o+1][j][0])\)

    \(f[i][o][j][0]=\min(f[i][o][j][0],f[i-1][o+1][j][1]+1)\)

答案:

当然是\(\min(f[n][0][0][1],f[n][0][0][0])\)

 

其实代码中好多取\(\min\)是不需要的,但是为了方便就都写上了懒得想

另外状态可能还能再优化?欢迎评论区指出

 

\(code.\),复杂度\(O(n^3)\)

#include<cstdio>
#include<algorithm>
#include<iostream>
#include<cmath>
#include<iomanip>
#include<cstring>
#define R register
#define EN printf("\n")
#define LL long long
inline int read(){
int x=0,y=1;
char c=std::getchar();
while(c<'0'||c>'9'){if(c=='-') y=-1;c=std::getchar();}
while(c>='0'&&c<='9'){x=x*10+(c^48);c=std::getchar();}
return x*y;
}
int n;
int f[106][106][106][2];
int a[106],num[2];
inline void min(int &x,int y){(x>y)&&(x=y);}
int main(){
n=read();
for(R int i=1;i<=n;i++){
a[i]=read();
if(!a[i]){a[i]=-1;continue;}
a[i]&=1;
num[a[i]]++;
}
num[1]=(n&1?n/2+1:n/2)-num[1];num[0]=n/2-num[0];
std::memset(f,0x3f,sizeof f);
if(a[1]==-1){
if(num[0]>0) f[1][num[0]-1][num[1]][0]=0;
if(num[1]>0) f[1][num[0]][num[1]-1][1]=0;
}
else if(a[1]) f[1][num[0]][num[1]][1]=0;
else f[1][num[0]][num[1]][0]=0;
for(R int i=2;i<=n;i++){
if(a[i]!=-1){
for(R int o=num[0];o>=0;o--){
for(R int j=num[1];j>=0;j--)
min(f[i][o][j][a[i]],f[i-1][o][j][1]+(a[i]!=1)),
min(f[i][o][j][a[i]],f[i-1][o][j][0]+(a[i]!=0));
}
continue;
}
for(R int o=num[0];o>=0;o--){
for(R int j=num[1];j>=0;j--){
min(f[i][o][j][1],f[i-1][o][j+1][1]);
min(f[i][o][j][1],f[i-1][o][j+1][0]+1);
min(f[i][o][j][0],f[i-1][o+1][j][0]);
min(f[i][o][j][0],f[i-1][o+1][j][1]+1);
}
}
}
std::printf("%d",std::min(f[n][0][0][1],f[n][0][0][0]));
return 0;
}

题解 CF1286A 【Garland】的更多相关文章

  1. C. Nice Garland Codeforces Round #535 (Div. 3) 思维题

    C. Nice Garland time limit per test 1 second memory limit per test 256 megabytes input standard inpu ...

  2. Codeforces 1108D - Diverse Garland - [简单DP]

    题目链接:http://codeforces.com/problemset/problem/1108/D time limit per test 1 secondmemory limit per te ...

  3. Codeforces Round #535 (Div. 3) 题解

    Codeforces Round #535 (Div. 3) 题目总链接:https://codeforces.com/contest/1108 太懒了啊~好久之前的我现在才更新,赶紧补上吧,不能漏掉 ...

  4. Codeforces Round #535(div 3) 简要题解

    Problem A. Two distinct points [题解] 显然 , 当l1不等于r2时 , (l1 , r2)是一组解 否则 , (l1 , l2)是一组合法的解 时间复杂度 : O(1 ...

  5. POJ1759 Garland —— 二分

    题目链接:http://poj.org/problem?id=1759 Garland Time Limit: 1000MS   Memory Limit: 10000K Total Submissi ...

  6. 【codeforces 758B】Blown Garland

    time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...

  7. Codeforces Round #612 (Div. 2) 前四题题解

    这场比赛的出题人挺有意思,全部magic成了青色. 还有题目中的图片特别有趣. 晚上没打,开virtual contest打的,就会前三道,我太菜了. 最后看着题解补了第四道. 比赛传送门 A. An ...

  8. Codeforces Round #611 (Div. 3) A-F简要题解

    contest链接:https://codeforces.com/contest/1283 A. Minutes Before the New Year 题意:给一个当前时间,输出离第二天差多少分钟 ...

  9. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

随机推荐

  1. MTK Android 设置下添加一级菜单[ZedielPcbTest]

    功能描述:Android7.1.2 设置下添加一级菜单[ZedielPcbTest],点击ZedielPcbTest,启动ZedielPcbTest.apk应用. 编译:需要在out目录删除Settt ...

  2. Java第十二天,权限修饰符

    Java当中权限修饰符共有四种.分别是public.protected.(default).private. 注:YSE代表可访问,NO代表不可访问.   同一个类 同一个包,非继承 不同的包,有继承 ...

  3. 在OS X环境下MySQL启动时报错

    --03T00::.483037Z [ERROR] InnoDB: Unable to lock ./ibdata1 error: --03T00::.483100Z [Note] InnoDB: C ...

  4. 31.2 try finally使用

    package day31_exception; import java.io.FileWriter; import java.io.IOException; import java.lang.Exc ...

  5. 使用 RestTemplate 进行第三方Rest服务调用

    1. 前言 RestTemplate 是 Spring 提供的一个调用 Restful 服务的抽象层,它简化的同 Restful 服务的通信方式,隐藏了不必要的一些细节,让我们更加优雅地在应用中调用 ...

  6. 从谷歌面试翻车到offer收割的心路历程

    首先声明,这只是我的播客随感,其中无法避免有一些个人色彩的见解,请不要在意,我尊敬任何的互联网公司,尊敬研究生期间的老师同学,我只希望给在求学路上的CS同学一些启发. 先介绍一下背景,我是ACM铜牌退 ...

  7. x聊之后,又一波新的诈骗套路

    前些天刚看到,x聊勒索诈骗套路,骗子的套路可以说是花样百出,这不又一网友深受其害. 事情经过是这样的 某被骗网友由于工资微薄一直想找副业增加收入,关注和加了很多群. 注意群里都是有偏亮头像的”小姐姐” ...

  8. Angular input / ion-input ion-searchbar 实现软件盘换行 改 搜索 并且触发搜索方法 Android iOS适用

    Angular 实现软件盘 换行 改 搜索 并且除非 搜索方法:    Form 必须有 action="javascript: return true;”   input / ion-in ...

  9. 006-循环结构(下)-C语言笔记

    006-循环结构(下)-C语言笔记 学习目标 1.[掌握]do-while循环结构 2.[掌握]for循环结构 3.[掌握]嵌套循环 一.do-while循环结构 do-while语法:   1 2 ...

  10. python批量添加hexo文章封面

    ❝ 本文需要工具: 「excel」 「python3.x」 ❞ 今天突然觉得,我的博客的文章更新这么多了竟然还没有一个封面,觉得首页相当低调了- 首页 正好皮肤带有文章封面功能,所以我觉得要将文章批量 ...