给定一个长度为n的整数序列,请找出最长的不包含重复的数的连续区间,输出它的长度。
[输入格式]
第一行包含整数n。
第二行包含n个整数(均在0~100000范围内),表示整数序列。[输出格式]
共一行,包含一个整数,表示最长的不包含重复的数的连续区间的长度。
[数据范围]
1≤n≤100000
[输入样例]
5
1 2 2 3 5[输出样例]
3
源代码
#include<iostream>
using namespace std;
const int N=100010;
int n,res;
int f[N],h[N];
int main(){
cin>>n;
for(int i=1;i<=n;i++)cin>>f[i];
for(int i=1,j=1;i<=n && j<=i;i++){
h[f[i]]++;
while(h[f[i]]>1){
h[f[j]]--;
j++;
}
res=max(res,i-j+1);
}
cout<<res<<endl;
return 0;
}