已知一个已经从小到大排序的数组,这个数组的一个平台(Plateau)就是连续的一串值相同的元素,并且这一串元素不能再延伸。例如,在 1,2,2,3,3,3,4,5,5,6中1,2-2,3-3-3,4,5-5,6都是平台。试编写一个程序,接收一个数组,把这个数组最长的平台找出 来。在上面的例子中3-3-3就是最长的平台。
Input
第一行有一个整数n(n <= 1000),为数组元素的个数。第二行有n个整数,整数之间以一个空格分开。
Output
输出最长平台的长度。
Sample Input
10
1 2 2 3 3 3 4 5 5 6
WA代码:
#include <iostream>
#include<cstdio>
#include<cmath>
using namespace std;
int main()
{
int n,i;
int cnt=1;
cin>>n;
int a[n],t;
for(i=0;i<n;i++)
{
cin>>a[i];
}
for(i=0;i<n;i++)
{
if(a[i+1]==a[i])
{
cnt++;
t=cnt;
// cout<<t<<endl;
}
else
cnt=1;
}
cout<<t;
return 0;
}
AC代码:
#include <iostream>
#include<cstdio>
#include<cmath>
using namespace std;
int main()
{
int n,i;
int cnt=1;
cin>>n;
int a[n],max=1;
for(i=0;i<n;i++)
{
cin>>a[i];
}
for(i=0;i<n;i++)
{
if(a[i+1]==a[i])
{
cnt++;
if(max<=cnt)
max=cnt;
}
else
{
cnt=1;
}
}
cout<<max;
return 0;
}