核心思想:将朴素算法优化到O(n)
应用实例
1.将一个字符串分割成单词
//将一个字符串分割成单词
#include<iostream>
#include<string.h>
using namespace std;int main()
{char str[1000];gets(str);int n=strlen(str);//trlen函数需要引入头文件#include<string.h>for(int i=0;i<n;i++){int j=i;while(j<n && str[j]!=' ') j++; //将空格视为单词之间的分隔符for(int k=i;k<j;k++) cout<<str[k];cout<<endl;i=j;}return 0;
}
2.最长连续不重复序列
#include<iostream>
using namespace std;
const int N=1e5+10;
int n;
int a[N],s[N];
int main()
{cin>>n;for(int i=0;i<n;i++) cin>>a[i];int res=0;for(int i=0,j=0;i<n;i++){s[a[i]]++;while(s[a[i]]>1){s[a[j]]--; // j 要把前面走过的个数都清掉j++;}res=max(res,i-j+1);}cout<<res<<endl;return 0;
}
测试样例:
5
1 2 2 3 5
输出:3