#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(1*sizeof(Node));
    newNode->data = num;
    newNode->next = NULL;
    if(head==NULL){
        head = newNode;
        tail = newNode;
    }
    else{
        tail->next = newNode;
        tail = newNode;
    }
}

void createAtFront(int val){
    Node *newNode=(Node*)malloc(1*sizeof(Node));
    newNode->data = val;
    newNode->next = NULL;
    if(head==NULL){
        head = newNode;
        tail = newNode;
    }
    else{
        tail->next = newNode;
        tail = newNode;
    }
}

Node *temp, *temp2;
void reverse(){
    temp = head;
    while(head != NULL){
        temp2 = head->next;
        head->next = temp;
        head = temp;
        head = temp2;
    }
    head = temp;
}

void display(){
    Node *itr;
    for(itr=head;itr != NULL;itr=itr->next){
        printf("%d ",itr->data);
    }
}

int main(){
    int size,i,num,val;
    scanf("%d",&size);
    if(size<=0){
        printf("Invalid input");
        return 0;
    }
    for(i=1;i<=size;i++){
        scanf("%d",&num);
        create(num);
    }
    scanf("%d",&val);
    createAtFront(val);
    reverse();
    display();
    return 0;
}