poj 3320 复习一下尺取法

Posted 不搞事情和咸鱼有什么区别

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了poj 3320 复习一下尺取法相关的知识,希望对你有一定的参考价值。

尺取法(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;
   }
}

以上是关于poj 3320 复习一下尺取法的主要内容,如果未能解决你的问题,请参考以下文章

poj3320 (尺取法)

poj3320尺取法

POJ 3320Jessica's Reading Problemc(尺取法)

poj 3320 Jessica's Reading Problem(尺取法)

尺取法POJ3061 & POJ3320

(尺取法)POJ 3320 Jessica's Reading Problem