DZY Loves Sequences
1 second
256 megabytes
standard input
standard output
DZY has a sequence a, consisting of n integers.
We'll call a sequence ai, ai + 1, ..., aj (1 ≤ i ≤ j ≤ n) a subsegment of the sequence a. The value (j - i + 1) denotes the length of the subsegment.
Your task is to find the longest subsegment of a, such that it is possible to change at most one number (change one number to any integer you want) from the subsegment to make the subsegment strictly increasing.
You only need to output the length of the subsegment you find.
The first line contains integer n (1 ≤ n ≤ 105). The next line contains n integers a1, a2, ..., an (1 ≤ ai ≤ 109).
In a single line print the answer to the problem — the maximum length of the required subsegment.
6
7 2 3 1 5 6
5
You can choose subsegment a2, a3, a4, a5, a6 and change its 3rd element (that is a4) to 4.
思路:预处理出包含第i个元素的左边最长连续递增长度 和 包含第i个元素的右边最长连续递增长度, 枚举可以任意改变的位置 pos, 然后判断该位置的左右两边是否可以连接以满足递增
#include <cstdio>
#include <cstring>
#include <cmath>
#include <iostream>
#include <algorithm>
#include <map>
using namespace std;
const int N = 100005;
int a[N], lt[N], rt[N], n;
int main()
{
scanf("%d", &n);
for(int i = 1; i <= n; ++i) scanf("%d", &a[i]);
lt[1] = 1;
for(int i = 2; i <= n; ++i) { //预处理i的左边且包含i的连续最长递增数列的长度
if(a[i] > a[i - 1]) lt[i] = lt[i - 1] + 1;
else lt[i] = 1;
} // for(int i = 1; i <= n; ++i) cout << lt[i] << ' ' ; cout << endl;
rt[n] = 1;
for(int i = n - 1; i >= 1; --i) { ////预处理i的右边且包含i的连续最长递增数列的长度
if(a[i] < a[i + 1]) rt[i] = rt[i + 1] + 1;
else rt[i] = 1;
}
// for(int i = 1; i <= n; ++i) cout << rt[i] << ' ' ; cout << endl;
int ans = max(rt[2] + 1, lt[n - 1] + 1);
for(int i = 2; i < n; ++i) {//枚举可任意更换的位置
if(a[i - 1] + 1 >= a[i + 1]) ans = max(ans, max(lt[i - 1], rt[i + 1]) + 1); // 若i的两边不能衔接, 取较大的长度
else ans = max(ans, lt[i - 1] + rt[i + 1] + 1);//否则为答案为 两段和
}
printf("%d\n", ans);
}
DZY Loves Sequences的更多相关文章
- cf446A DZY Loves Sequences
		A. DZY Loves Sequences time limit per test 1 second memory limit per test 256 megabytes input standa ... 
- codeforces#FF DIV2C题DZY Loves Sequences(DP)
		题目地址:http://codeforces.com/contest/447/problem/C C. DZY Loves Sequences time limit per test 1 second ... 
- Codeforces Round #FF (Div. 2):C. DZY Loves Sequences
		C. DZY Loves Sequences time limit per test 1 second memory limit per test 256 megabytes input standa ... 
- Codeforces Round #FF  446A DZY Loves Sequences
		预处理出每一个数字能够向后延伸多少,然后尝试将两段拼起来. C. DZY Loves Sequences time limit per test 1 second memory limit per t ... 
- [CodeForces - 447C] C - DZY Loves Sequences
		C - DZY Loves Sequences DZY has a sequence a, consisting of n integers. We'll call a sequence ai, ai ... 
- Codeforces 447C - DZY Loves Sequences
		447C - DZY Loves Sequences 思路:dp 代码: #include<bits/stdc++.h> using namespace std; #define ll l ... 
- Codeforces Round #FF (Div. 1) A. DZY Loves Sequences 动态规划
		A. DZY Loves Sequences 题目连接: http://www.codeforces.com/contest/446/problem/A Description DZY has a s ... 
- DP Codeforces Round #FF (Div. 1) A. DZY Loves Sequences
		题目传送门 /* DP:先用l,r数组记录前缀后缀上升长度,最大值会在三种情况中产生: 1. a[i-1] + 1 < a[i+1],可以改a[i],那么值为l[i-1] + r[i+1] + ... 
- C. DZY Loves Sequences
		C. DZY Loves Sequences time limit per test 1 second memory limit per test 256 megabytes input standa ... 
随机推荐
- 【linux】英文显示乱码解决
			在linux环境中中文显示正常,而英文却显示乱码 用 echo $LANG 显示编码为 zh_CN.GB18030 解决方法: 输入 export LC_ALL=POSIX 即可 
- 20145213《Java程序设计》第五周学习总结补充
			20145213<Java程序设计>第五周学习总结补充 教材学习内容总结 欠的账都是要还的!第九章的内容躲过对酒当歌的夜,躲不过四下无人的街.由于第五周贪玩,疏忽冷落了Collection ... 
- 使用rdesktop连接Windows远程桌面
			rdesktop 使用简单,windows也不和装什么服务端,是要把远程桌面共享打开就行了 安装 yum -y install rdesktop 具体使用方法要先打开终端,然后输入以下命令: rdes ... 
- Keepalived虚拟ip
			linux下如何设置vip(虚拟ip) 在做HA的时候需要为服务器设计虚拟IP,也就是一个主机对应多个IP地址?刚听起来好神奇,原来这样也是可能的看了下面的这个链接 自己配了一下http://hi.b ... 
- 用fontAwesome代替网页icon小图标
			1. 引言 网页小图标到处可见,如果一个网页都是干巴巴的文字和图片,而没有小图标,会显得非常简陋.下面的小图标,你是不是会经常用到? 你可能说——“我们用的都是彩色的,不是黑白的”——别着急,下面会讲 ... 
- asp.net 曲线图
			public void draw(DataTable dt) { //取得记录数量 int count = dt.Rows.Count; //记算图表宽度 int wd = 80 + 20 * (co ... 
- hdu5878(枚举,打表)
			题目链接:hdu5878 题意:到一行输入t,表示下面有t组数据,然后下面t行每行输入一个数n; 定义x==2^a*3^b*5^c*7^d(a, b, c, d为自然数,x不大于1e+9): 要求对于 ... 
- Android Programming: Pushing the Limits -- Chapter 7:Android IPC -- AIDL
			服务端: 最终项目结构: 这个项目中,我们将用到自定义类CustomData作为服务端与客户端传递的数据. Step 1:创建CustomData类 package com.ldb.android.e ... 
- windows重新获取IP
			win+r------->cmd------>ipconfig /release (释放ip) ipconfig /renew 重新获取ip 
- Linux系统监控命令及如何定位到Java线程
			>>PID.TID的区分 uid是user id,即用户id,root用户的uid是0,0为最高权限,gid是group id,用户组id,使用 id 命令可以很简单的通过用户名查看UID ... 
