题解 CF1286A 【Garland】
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】的更多相关文章
- 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 ...
- Codeforces 1108D - Diverse Garland - [简单DP]
题目链接:http://codeforces.com/problemset/problem/1108/D time limit per test 1 secondmemory limit per te ...
- Codeforces Round #535 (Div. 3) 题解
Codeforces Round #535 (Div. 3) 题目总链接:https://codeforces.com/contest/1108 太懒了啊~好久之前的我现在才更新,赶紧补上吧,不能漏掉 ...
- Codeforces Round #535(div 3) 简要题解
Problem A. Two distinct points [题解] 显然 , 当l1不等于r2时 , (l1 , r2)是一组解 否则 , (l1 , l2)是一组合法的解 时间复杂度 : O(1 ...
- POJ1759 Garland —— 二分
题目链接:http://poj.org/problem?id=1759 Garland Time Limit: 1000MS Memory Limit: 10000K Total Submissi ...
- 【codeforces 758B】Blown Garland
time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...
- Codeforces Round #612 (Div. 2) 前四题题解
这场比赛的出题人挺有意思,全部magic成了青色. 还有题目中的图片特别有趣. 晚上没打,开virtual contest打的,就会前三道,我太菜了. 最后看着题解补了第四道. 比赛传送门 A. An ...
- Codeforces Round #611 (Div. 3) A-F简要题解
contest链接:https://codeforces.com/contest/1283 A. Minutes Before the New Year 题意:给一个当前时间,输出离第二天差多少分钟 ...
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
随机推荐
- Deep Dream模型与实现
Deep Dream是谷歌公司在2015年公布的一项有趣的技术.在训练好的卷积神经网络中,只需要设定几个参数,就可以通过这项技术生成一张图像. 本文章的代码和图片都放在我的github上,想实现本文代 ...
- easy-mock 本地部署(挤需体验三番钟,里造会干我一样,爱象节款mock)
前言 很多小伙伴问我怎么在自己公司的项目里面添加配置mock,在vue项目里面都知道怎么配置mock,在大型前端项目里面就一脸疑惑了. 我就回答他,你今天会在vue项目里面用,那天换公司是用angul ...
- Python 1基础语法四(数字类型、输入输出汇总和命令行参数)
一.数字(Number)类型 python中数字有四种类型:整数.布尔型.浮点数和复数. int (整数), 如 1, 只有一种整数类型 int,表示为长整型,没有 python2 中的 Long. ...
- xftp连接centos7
1.下载xftp文件,并正常进行安装 2.安装好之后运行,并新建会话,此时可见如下界面: 注意: 名称,可随便输入,自己能看懂是什么就行 主机,输入当前Linux服务器的ip(如何获取服务器 ...
- hibernate.current_session_context_class 比较权威的解释
hibernate.current_session_context_class 博客分类: hibernate HibernateSpring多线程配置管理thread 遇到过的问题: 情景1: 在 ...
- AJ学IOS(29)UI之Quartz2D自定义下载控件_画各种图形
AJ分享,必须精品 效果 自定义控件过程 主要过程在上一篇里有介绍了,这里主要介绍下代码实现 先做好要放的view 然后实现呢主要就是四步: 1:获取上下文 2:拼接路径 3:把路径添加到上下文. 4 ...
- MySQL的事务隔离级别是什么?
我是平也,这有一个专注Gopher技术成长的开源项目「go home」 背景介绍 想必事务大家都已经非常熟悉了,它是一组SQL组成的一个执行单元,要么全执行要么全不执行,这也是它的一个特性--原子性. ...
- IP连接数据库语句
select * from [19.200.108.2].[jsoctnetv6.0].[CardInfo] where ICNO='32719'
- stand up meeting 1/15/2016 && work of weekend 1/16/2016~1/17/2016
part 组员 工作 工作耗时/h 明日计划 工作耗时/h UI 冯晓云 组内对生词卡片又重新进行了讨论:准备最后的发布和整个开发的整理 ...
- search(6)- elastic4s-CRUD
如果我们把ES作为某种数据库来使用的话,必须熟练掌握ES的CRUD操作.在这之前先更正一下上篇中关于检查索引是否存在的方法:elastic4s的具体调用如下: //删除索引 val rspExists ...