#include<cstdio>
inline int read(){
int x=0,f=1;
char ch=getchar();
while(ch<'0'||ch>'9'){
if(ch=='-')f=-1;
ch=getchar();
}
while(ch>='0'&&ch<='9'){
x=(x<<1)+(x<<3)+(ch^48);
ch=getchar();
}
return x*f;
}
using namespace std;
int main(){
int n,k;
n=read(),k=read();
int a[50000005],c[50000005];
for(int i=1;i<=n;++i){
a[i]=read();
c[i]=a[i];
}
if(k>1000){
k=k%(n);
for(int j=1;j<=k;++j){
for(int i=1;i<=n;++i)a[i]=c[a[i]];
for(int i=1;i<=n;++i)c[i]=a[i];
}
for(int i=1;i<=n;++i)printf("%d ",a[i]);
return 0;
}
for(int j=1;j<=k;++j){
for(int i=1;i<=n;++i)a[i]=c[a[i]];
for(int i=1;i<=n;++i)c[i]=a[i];
}
for(int i=1;i<=n;++i)printf("%d ",a[i]);
}