#include<stdio.h>
#include<stdlib.h>
typedef struct node{
    int data;
    struct node *next;
}Node;
Node *head=NULL,*tail;
void create(int num){
    Node *newnode=(Node*)malloc(sizeof(Node));
    newnode->data=num;
    newnode->next=NULL;
    if(head==NULL){
        head=newnode;
        tail=newnode;
    }
    else{
        tail->next=newnode;
        tail=newnode;
    }
}
void insert(int val,int pos,int size){
    Node *newnode=(Node*)malloc(sizeof(Node));
    newnode->data=val;
    newnode->next=NULL;
    Node *first=head;
    Node *second=head->next;
        if(pos=1){
            newnode->next=head;
            head=newnode;
        }
        if(pos=size+1){
            tail->next=newnode;
            tail=newnode;
        }
        else {
            int cnt=1;
             Node *itr=head;
             while(1){
                 if(cnt+1==pos){
                     newnode->next=itr->next;
                     itr->next=newnode;
                     break;
                 }
                itr=itr->next;
                cnt++;
             }
        }
    
}
void display(){
    Node *itr;
    for(itr=head;itr!=NULL;itr=itr->next){
        printf("%d ",itr->data);
    }
}
int main(){
    int size,itr,num;
    int val,pos;
    scanf("%d",&val);
    scanf("%d",&size);
    scanf("%d",&pos);
    for(itr=0;itr<size;itr++){
        scanf("%d",&num);
        create(num);
    }
    insert(val,pos,size);
    display();
    return 0;
}