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