#include<bits/stdc++.h>
using namespace std;
const int N=8e6+100;
int n,m,a[N],sum[N],x,y;
void build(int o,int l,int r){
if(l==r){
sum[o]=a[l];
return;
}
int mid=(l+r)/2;
build(o*2,l,mid);
build(o*2+1,mid+1,r);
sum[o]=min(sum[o*2],sum[o*2+1]);
}
int query(int o,int l,int r){
if(x<=l&&r<=y)return sum[o];
int ans=INT_MAX,mid=(l+r)/2;
if(x<=mid)ans=min(query(o*2,l,mid),ans);
if(y>mid)ans=min(query(o*2+1,mid+1,r),ans);
return ans;
}
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++)cin>>a[i];
build(1,1,n);
cout<<0<<endl;
for(int i=2;i<=n;i++){
int x=max(i-m,1),y=i-1;
cout<<query(1,1,n)<<endl;
}
return 0;
}