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. Web前端必备-Nginx知识汇总

    一.Nginx简介 Nginx是一个高性能.轻量级的Web和反向代理服务器, 其特点是占有内存及资源少.抗并发能力强. Nginx安装简单.配置简洁.启动快速便捷.支持热部署.支持 SSL.拥有高度模 ...

  2. 19cRAC增删节点

    由于测试环境打19c补丁失败,导致节点2  d2 crs无法启动!打补丁没有有效备份,亲人两行泪 先删再加节点. 一.删除节点 1.1 删除实例 参考 https://www.cnblogs.com/ ...

  3. Java成长第五集--面向对象设计的五大原则

    S.O.L.I.D 是面向对象设计(OOD)和面向对象编程(OOP)中的几个重要编码原则(Programming Priciple)的首字母缩写.以下图说明: 下面就个人的理解来说说这五大原则的含义到 ...

  4. AJ学IOS 之微博项目实战(7)程序启动新特性用UICollectionViewController实现

    AJ分享,必须精品 一:效果 这里实现了大多数app都会有的软件新特性的功能,用的是UICollectionViewController实现的 二:思路 这里用了UICollectionViewCon ...

  5. 造轮子:实现一个简易的 Spring IoC 容器

    作者:DeppWang.原文地址 我通过实现一个简易的 Spring IoC 容器,算是入门了 Spring 框架.本文是对实现过程的一个总结提炼,需要配合源码阅读,源码地址. 结合本文和源码,你应该 ...

  6. 亲测可以使用的Axmath和MathPix插入word公式

    Axmath破解版链接 链接:https://pan.baidu.com/s/1Phak8mc3msKAMQ6H_5EN5g 提取码:glti MathPixTool和Axmath共同使用向word插 ...

  7. Atcoder E - Crested Ibis vs Monster、

    一看到题目就觉得是一个背包问题,但是不知道怎么写. 题解:直接求背包容量为2*h时所需要的花费.然后h~2h都是满足条件的,去最小值即可. code: #include<bits/stdc++. ...

  8. E2. Send Boxes to Alice (Hard Version)

    秒的有点难以理解:https://blog.csdn.net/weixin_42868863/article/details/103200132 #include<bits/stdc++.h&g ...

  9. 落谷 P1734 最大约数和

    题目描述 选取和不超过S的若干个不同的正整数,使得所有数的约数(不含它本身)之和最大. 输入格式 输入一个正整数S. 输出格式 输出最大的约数之和. 输入输出样例 输入 #1复制 11 输出 #1复制 ...

  10. [GitHub] 75+的 C# 数据结构和算法实现

    C#中标准数据结构和算法的即插即用类库项目 GitHub:https://github.com/aalhour/C-Sharp-Algorithms Watch: 307 Star: 3.4k For ...