給定乙個長度為n的整數序列,請找出最長的不包含重複數字的連續區間,輸出它的長度。輸入格式
第一行包含整數n。
第二行包含n個整數(均在0~100000範圍內),表示整數序列。
輸出格式
共一行,包含乙個整數,表示最長的不包含重複數字的連續子串行的長度。
資料範圍
1≤n≤100000
輸入樣例:
51 2 2 3 5
輸出樣例:
3這道題採用雙指標做法,對於乙個數字,以該數字為結尾,然後向前計算滿足不包含重複數字的最大長度。
使用雙指標的好處是,可以讓時間複雜度降到o(n)。我們可以使用乙個陣列來統計每個數字出現的次數,如果出現的次數大於1,則說明已經有重複的數字出現,記錄下當前區間的長度,並且將之前統計的數字清零,然後輸出最終答案即可。
#include
#include
#define ios ios::sync_with_stdio(false)
using
namespace std;
const
int maxn=
1e6+10;
int a[maxn]
,q[maxn]
;int n,ans=0;
bool flag=
true
;int
main()
ans=
max(ans,i-j+1)
;}cout<}
最長連續不重複子序列
給定乙個長度為n的整數序列,請找出最長的不包含重複數字的連續區間,輸出它的長度。第一行包含整數n。第二行包含n個整數 均在0 100000範圍內 表示整數序列。共一行,包含乙個整數,表示最長的不包含重複數字的連續子串行的長度。1 n 100000 51 2 2 3 5 暴力 for int i 0 ...
最長連續不重複子序列
核心思路 遍歷陣列a中的每乙個元素a i 對於每乙個i,找到j使得雙指標 j,i 維護的是以a i 結尾的最長連續不重複子序列,長度為i j 1,將這一長度與result的較大者更新給result。對於每乙個i,如何確定j的位置 由於 j,i 1 是前一步得到的最長連續不重複子序列,所以如果 j,i...
最長不重複子序列
其實是一道典型的雙指標問題,只要一直往後去輸入資料,如果遇到重複的資料,就讓begin指標往後移,直到重複的元素不再子串行內,在讀入新資料就可以了,每次遇到重複資料就把maxlength和當前的length比較去大值,就可以了 include include include include incl...