题目:[USACO Jan07] 均衡队形
描述:
农夫约翰的 N (1 ≤ N ≤ 50,000) 头奶牛,每天挤奶时总会按同样的顺序站好。一日,农夫约翰决定为奶牛们举行一个“终极飞盘”比赛。为简化问题,他将从奶牛队列中选出一个连续区间来进行游戏。不过,参加游戏的奶牛要玩的开心的话就不能在身高上差距太大。
农夫约翰制定了 Q (1 ≤ Q ≤ 200,000) 个预定的参赛组,给出它们的身高 (1 ≤ 身高 ≤ 1,000,000)。对每个参赛组,他需要你帮助确定组中最高牛和最低牛的身高差。
6 3 1 7 3 4 2 5 1 5 4 6 2 2
6 3 0
该题较水,还是果的RMQ算法,只是多加了一个数组存储而已,并没有难度,一遍AC木有了。
AC代码:
{
program zht; var i,j,n,m,q,w,l,r,x:longint; a:array[0..50000] of longint; f1,f2:array[0..50000,0..20] of longint; function max(a,b:longint):longint; begin if a>b then max:=a else max:=b; end; function min(a,b:longint):longint; begin if a<b then min:=a else min:=b; end; begin assign(input,‘lineup.in‘); assign(output,‘lineup.out‘); reset(input); rewrite(output); readln(n,m); fillchar(f1,sizeof(f1),0); for i:=1 to n do begin read(a[i]); f1[i,0]:=a[i]; f2[i,0]:=a[i]; end; for j:=1 to trunc(ln(n)/ln(2)) do for i:=1 to n+1-(1 shl j) do begin f1[i,j]:=min(f1[i,j-1],f1[i+1 shl (j-1),j-1]); f2[i,j]:=max(f2[i,j-1],f2[i+1 shl (j-1),j-1]); end; for i:=1 to m do begin readln(l,r); x:=trunc(ln(r-l+1)/ln(2)); q:=min(f1[l,x],f1[r+1-(1 shl x),x]); w:=max(f2[l,x],f2[r+1-(1 shl x),x]); writeln(w-q); end; close(input); close(output); end.
}
原文:http://www.cnblogs.com/zhtjtcz/p/4992841.html