洛谷P1420 最长连号

题目描述

输入n个正整数,(1<=n<=10000),要求输出最长的连号的长度。(连号指从小到大连续自然数)

输入输出格式

输入格式:

第一行,一个数n;

第二行,n个正整数,之间用空格隔开。

输出格式:

一个数,最长连号的个数。

输入输出样例

输入样例#1: 复制

10
3 5 6 2 3 4 5 6 8 9
           

输出样例#1: 复制

5

这个题我用动态规划来做,首先设置ans数组,第一项设为1,之后如果满足a数组的后一项等于前项+1,则ans的对应项+1,否则重新置为1,最好排序ans数组,输出其最大项极为答案。

#include<iostream>
#include<algorithm>
using namespace std;
int main() {
	int n;
	cin>>n;
	int a[10001];
	int ans[10001];
	for(int i=0;i<n;i++){
		cin>>a[i];
	} 
	ans[0] = 1;
	for(int i=0;i<n;i++){
		if(a[i]+1==a[i+1]){
			ans[i+1] = ans[i]+1; 
			
		}
		else {
			ans[i+1] = 1;
		}
		
		
	} 

	sort(ans,ans+n);
	cout<<ans[n-1]<<endl;
	return 0;
}

猜你喜欢

转载自blog.csdn.net/qq_41319370/article/details/85227172