ArcTan

dfs
随笔 - 16, 文章 - 117, 评论 - 6, 引用 - 0
数据加载中……

poj2832(单调队列)----原来就是贪心啊!!!

:jh辉神说,单调队列单调栈就是贪心嘛,哎哎,怪自己太无知了!!!!

windows,找出区间的最大最小元素,单调队列的经典应用嘛。
应该说,贪心的思想,方法,单调队列是实现的技术才好吧。
poj2832
一次AC,要多理解问题的本质啊!!!
#include<stdio.h>
#include
<string.h>
#include
<math.h>
int n,k;
int a[1000005],q[1000005];
int main()
{
    
int i,head,tail;
    printf(
"%d\n",(30<<1)*3);
    
while (scanf("%d%d",&n,&k)==2)
    {
        
for (i=1; i<=n ; i++)
            scanf(
"%d",&a[i]);
        head
=1;
        tail
=0;
        memset(q,
0,sizeof(q));
        
for (i=1; i<=n ; i++ )
        {
            
while (head<=tail&&a[q[tail]]>=a[i])
                tail
--;
            tail
++;
            q[tail]
=i;
            
while (q[head]<=i-k)
                head
++;
            
if (i>=k)
                printf(
"%d ",a[q[head]]);
        }
        printf(
"\n");
        head
=1;
        tail
=0;
        memset(q,
0,sizeof(q));
        
for (i=1; i<=n ; i++ )
        {
            
while (head<=tail&&a[q[tail]]<=a[i])
                tail
--;
            tail
++;
            q[tail]
=i;
            
while (q[head]<=i-k)
                head
++;
            
if (i>=k)
                printf(
"%d ",a[q[head]]);
        }
        printf(
"\n");
    }
    
return 0;
}
额,这个pascal的代码好熟悉啊:
var
  n
,k,i,head,tail:longint;
  a,q:array[0..1000001] of longint;

begin
  readln(n
,k);
  for i:=1 to n do
    read(a
[i]);
  head:=1;tail:=0;
  for i:=1 to n do
    begin
      while (head<
=tail) and (a[q[tail]]>=a[i]) do dec(tail);
      inc(tail);
      q[tail]:=i;
      while q[head]<=i-k do inc(head);
      if i>=k then write(a[q[head]],' ');
    end;
  writeln;
  fillchar(q,sizeof(q),0);
  head:=1;tail:=0;
  for i:=1 to n do
    begin
      while (head<
=tail) and (a[q[tail]]<=a[i]) do dec(tail);
      inc(tail);
      q[tail]:=i;
      while q[head]<=i-k do inc(head);
      if i>=k then write(a[q[head]],' ');
    end;
  writeln;
end.
居然能没有pascal???


posted on 2012-04-25 22:48 wangs 阅读(272) 评论(0)  编辑 收藏 引用 所属分类: ACM-数据结构


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理