【POJ 3320】Jessica's Reading Problemc(尺取法)
题意
P个数,求最短的一段包含P个数里所有出现过的数的区间。
分析
尺取法,边读边记录每个数出现次数num[d[i]],和不同数字个数n个。
尺取时,l和r 代表区间两边,每次r++时,d[r]即r的出现次数+1,d[l]即l的出现次数大于1时,左边可以短一点,d[l]--,l++,直到d[l]出现次数为1,当不同数达到n个,且区间更小,就更新答案。
代码
#include <cstdio> #include <map> using namespace std; map <int,int> num,v; int p,l,r,n,cnt; int d[1000005]; int ans=9999999; int main() { scanf("%d", &p); for (int i = 0; i < p; i++) { scanf("%d",&d[i]); if (num[d[i]]==0) { n++; } num[d[i]]++; } l=0; r=0; while(l<p && r<p) { if (v[d[r]]==0) { cnt++; } v[d[r]]++; r++; while (v[d[l]]>1) { v[d[l]]--; l++; } if (cnt==n && r-l < ans) { ans=r-l; } } printf("%d",ans); return 0; }
┆凉┆暖┆降┆等┆幸┆我┆我┆里┆将┆ ┆可┆有┆谦┆戮┆那┆ ┆大┆始┆ ┆然┆
┆薄┆一┆临┆你┆的┆还┆没┆ ┆来┆ ┆是┆来┆逊┆没┆些┆ ┆雁┆终┆ ┆而┆
┆ ┆暖┆ ┆如┆地┆站┆有┆ ┆也┆ ┆我┆ ┆的┆有┆精┆ ┆也┆没┆ ┆你┆
┆ ┆这┆ ┆试┆方┆在┆逃┆ ┆会┆ ┆在┆ ┆清┆来┆准┆ ┆没┆有┆ ┆没┆
┆ ┆生┆ ┆探┆ ┆最┆避┆ ┆在┆ ┆这┆ ┆晨┆ ┆的┆ ┆有┆来┆ ┆有┆
┆ ┆之┆ ┆般┆ ┆不┆ ┆ ┆这┆ ┆里┆ ┆没┆ ┆杀┆ ┆来┆ ┆ ┆来┆