码迷,mamicode.com
首页 > 其他好文 > 详细

poj 3320 复习一下尺取法

时间:2017-03-18 18:18:16      阅读:134      评论:0      收藏:0      [点我收藏+]

标签:简单   with   define   name   efi   main   更新   bre   point   

尺取法(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 复习一下尺取法

标签:简单   with   define   name   efi   main   更新   bre   point   

原文地址:http://www.cnblogs.com/z1141000271/p/6574685.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!