尺取法Jessica's Reading Problem

Posted zyysyang

tags:

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

  • Step1 Problem

原题
一个人复习一本书,这本书的每一页都有一个知识点ai,每一页的知识点可能会与其他页的知识点相同,问你如何读最少页,将所以知识点读完。

  • Step2 Ideas:

尺取法通常是指对数组保存下一对下标(起点、终点),燃豆很具实际情况交替推进两个端点直到得出答案的方法。确定下知识点的个数,便用尺取法推进得到答案。

  • Step3 Code:
#include<iostream>
#include<stdio.h>
#include<iomanip>
#include<queue>
#include<algorithm>
#include<cstring>
#include<map>
#include<cmath>
#include<set>
#define mem(a,x) memset(a,x,sizeof(a));
using namespace std;
typedef long long ll;
const int inf = 0x3f3f3f3f;
const ll INF = 0x3f3f3f3f3f3f3f3f;
const int maxn = 1e5+5;
set<ll> se;
map<ll, ll> ma;
ll a[maxn];

int main()

    ll n;
    scanf("%lld", &n);
    for(ll i = 0;i < n; i++)
    
        scanf("%lld", &a[i]);
        se.insert(a[i]);
    
    ll num = se.size();
    ll tot = 0, tot1 = 0, sum = 0;
    ll ans = INF;
    for( ; ; )
    
        while(tot1 < n && sum < num)
        
            if(ma[a[tot1++]]++ == 0) sum++;
        
        if(sum < num) break;
        ans = min(ans, tot1 - tot);
        if(--ma[a[tot++]] == 0) sum--;
    
    printf("%lld\n", ans);
    return 0;

以上是关于尺取法Jessica's Reading Problem的主要内容,如果未能解决你的问题,请参考以下文章

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

题解报告:poj 3320 Jessica's Reading Problem(尺取法)

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

尺取法Jessica's Reading Problem

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

poj 3320 Jessica's Reading Problem