尺取法(two point)的思想不难,简单来说就是以下三步:

1。对r point在满足题意的情况下不断向右延伸

2。对l point前移一步 

3.  回到1

two point 对连续区间的问题求解有其独到之处 复杂度为0(n) 很实用的 

#include<iostream>
#include<map>
#include<set>
#include<vector>
#include<cstdio>
#define inf 1000002
using namespace std;
int a[inf];
int main()
{
    //cin.sync_with_stdio(false);
   int n;
   set<int> all;
   while(~scanf("%d",&n))
   {
       all.clear();
       map<int,int> mapp;
       for(int i=1;i<=n;i++)
       {
           scanf("%d",&a[i]);
           all.insert(a[i]);
       }
       int len = all.size();
       int e,num,s;
       s = e = 1;
       num = 0;
       int minlen = inf;
       while(1)
       {
           while(num < len && e<=n)// 向右延伸
           {
                if(mapp[a[e++]]++ == 0)
                {
                    num++;
                }
           }
           if(num < len) break;// 延伸不下去的时候 要结束啦
           minlen=min(minlen, e-s);
           if(--mapp[a[s++]] == 0)// letf point 的更新
               num--;
       }
       cout<<minlen<<endl;
   }
}

相关文章:

  • 2021-12-20
  • 2022-12-23
  • 2021-08-23
  • 2022-12-23
  • 2021-09-28
  • 2022-02-16
  • 2022-12-23
猜你喜欢
  • 2021-09-21
  • 2021-06-23
  • 2021-04-19
  • 2022-02-01
  • 2021-10-09
  • 2022-01-19
  • 2021-06-12
相关资源
相似解决方案