【Codeforces 933A】A Twisty Movement
【链接】 我是链接,点我呀:)
【题意】
【题解】
因为只有1和2.
所以最后肯定是若干个1接着若干个2的情况。
即11...11222...222这样的。
1.首先考虑没有翻转的情况。
那么就直接枚举1和2的边界i在什么地方,即1..i全是1,i+1..n全是2.
只需统计某个范围里面1和2的个数就可以了。
然后取最大值就ok.
2.考虑有翻转的情况.
假设翻转的区间是[i..j]
我们最好先固定j然后让i从j递减到1这样变化.
这样的话我们可以利用[i+1,j]这一段得到的东西继续搞,不用每次都重新算.
(注意倒过来以后相当于j是开始位置
我们可以对于这段区间维护两个变量
int pre1max = 0,pre2max = 0;
他们俩分别表示[i..j]这一段倒过来以后,以1作为结尾的LIS的长度和以2作为结尾的LIS的长度.
然后遇到了1的话,pre1max=pre1max+1.(因为只能在前面的1后面再接一个1
如果遇到了2的话,pre2max=max(pre2max,pre1max)+1;(表示既能在2后面接一个2也能在1后面接一个2).
然后对于每一段的i..j求出来一个pre1max和pre2max之后,都
用"1到i-1里面1的个数"+pre2max+"j+1到n里面2的个数"来更新最大值
(注意这个翻转肯定只能包括上面说的1和2的边界处翻转才有效果,否则如果是在11111..11这一段或者在22222..22这一段翻转的话,显然不会影响答案.
(这种情况就相当于没有翻转的情况了.
【代码】
#include <bits/stdc++.h>
using namespace std;
const int N = 2000;
int n;
int a[N+10];
int pre[N+10][3];
int getsum(int p,int l,int r){
if (l==0) return pre[r][p];
if (l>r) return 0;
return pre[r][p]-pre[l-1][p];
}
int main()
{
ios::sync_with_stdio(0),cin.tie(0);
cin >> n;
for (int i = 1;i <= n;i++) cin >> a[i];
for (int i = 1;i <=n;i++){
for (int j = 1;j <= 2;j++)
pre[i][j] = pre[i-1][j];
pre[i][a[i]]++;
}
int ans = 0+getsum(2,1,n);
for (int i = 1;i <= n;i++)
ans = max(ans,getsum(1,1,i)+getsum(2,i+1,n));
for (int j = n;j >= 1;j--){
int pre1max = 0,pre2max = 0;
if (a[j]==1) pre1max = 1;else pre2max = 1;
for (int i = j-1;i >= 1;i--){
if (a[i]==1){
pre1max++;
}else{
pre2max=max(pre2max,pre1max)+1;
}
ans = max(ans,getsum(1,1,i-1)+pre2max+getsum(2,j+1,n));
}
}
cout<<ans<<endl;
return 0;
}
【Codeforces 933A】A Twisty Movement的更多相关文章
- 【codeforces 415D】Mashmokh and ACM(普通dp)
[codeforces 415D]Mashmokh and ACM 题意:美丽数列定义:对于数列中的每一个i都满足:arr[i+1]%arr[i]==0 输入n,k(1<=n,k<=200 ...
- 【codeforces 750D】New Year and Fireworks
time limit per test2.5 seconds memory limit per test256 megabytes inputstandard input outputstandard ...
- 【codeforces 707E】Garlands
[题目链接]:http://codeforces.com/contest/707/problem/E [题意] 给你一个n*m的方阵; 里面有k个联通块; 这k个联通块,每个连通块里面都是灯; 给你q ...
- 【codeforces 707C】Pythagorean Triples
[题目链接]:http://codeforces.com/contest/707/problem/C [题意] 给你一个数字n; 问你这个数字是不是某个三角形的一条边; 如果是让你输出另外两条边的大小 ...
- 【codeforces 709D】Recover the String
[题目链接]:http://codeforces.com/problemset/problem/709/D [题意] 给你一个序列; 给出01子列和10子列和00子列以及11子列的个数; 然后让你输出 ...
- 【codeforces 709B】Checkpoints
[题目链接]:http://codeforces.com/contest/709/problem/B [题意] 让你从起点开始走过n-1个点(至少n-1个) 问你最少走多远; [题解] 肯定不多走啊; ...
- 【codeforces 709C】Letters Cyclic Shift
[题目链接]:http://codeforces.com/contest/709/problem/C [题意] 让你改变一个字符串的子集(连续的一段); ->这一段的每个字符的字母都变成之前的一 ...
- 【Codeforces 429D】 Tricky Function
[题目链接] http://codeforces.com/problemset/problem/429/D [算法] 令Si = A1 + A2 + ... + Ai(A的前缀和) 则g(i,j) = ...
- 【Codeforces 670C】 Cinema
[题目链接] http://codeforces.com/contest/670/problem/C [算法] 离散化 [代码] #include<bits/stdc++.h> using ...
随机推荐
- winrar
winrar 破解方法 1.安装winrar试用版: 2.在winrar安装文件夹下新建一个文本文件,文件名为rarreg.key: 3.用记事本打开该文件,将下面内容复制到文件中,并存盘,搞定! R ...
- spring boot测试
今天在springside里试了spring boot,果然很方便,内置容器,不需要配置web.xml,简单几个文件就可以实现增删改查操作,一些配置如tomcat端口之类的直接写在applicatio ...
- Java语言中的程序流程控制
(1. 流程控制 有三种基本技术可以改变程序的控制流程: A.调用方法 :将导致控制流程离开当前方法,转移到被调用的方法. B.选择 : a. if / else 语句 b. switch语句 ...
- 3d数学 7 矩阵
7.1 矩阵-数学定义 在线性代数中, 矩阵就是以行和列形式组织的矩形数字块.矩阵是向量的数组. 7.1.1 矩阵的维度和记法 矩阵的维度被定义为它包含了多少行和多少列.一个\(r \times c\ ...
- 网络流模板(模板题:POJ1273)
模板题:POJ1273 EK: #include <queue> #include <cstdio> #include <cstring> #include < ...
- fontSpider字蛛,好用的字体压缩工具教程
一直觉得很多字体特别好看,但是那些好看的字体只能做在图片上不能用CSS样式去实现,作为一个会设计的前端,真心觉得很烦恼,有时候那些文字需要更换,修改起来非常麻烦,要到处去找源文件,找不到源文件还要尽力 ...
- C#方法的练习
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Demo ...
- 易企CMS仿站标签说明
头部标签: 每个页面都必须加的三大标签(将标签放入header.tpl里面,这样只需在每个模板中调用header.tpl即可): <title>{$seotitle}_{$sitename ...
- 怪异的Ubuntu
怪异的Ubuntu 简单记录ubuntu上出现并且网上不好找到甚至压根找不到解决方案的疑难杂症. lvextend扩展逻辑卷的容量不能被系统检测到 问题发生在Ubuntu 16.04系统上. 逻辑卷/ ...
- 复习java基础第二天(异常处理)
一.常见的异常类型: public class TestException { public static void main(String[] args) { int i = 10; //数学异常: ...