#include<stdio.h>
#include<stdlib.h>
#include<string.h>
struct Node{
    int id;
    int priority;
    struct Node* next;
};
struct Node* head=NULL;
void insert(int id,int priority){
    struct Node* newNode=(struct Node*)malloc(sizeof(struct Node));
newNode->id=id;
newNode->priority=priority;
newNode->next=NULL;
        if(head==NULL||priority>head->priority){
            newNode->next=head;
            head=newNode;
            return ;
        }
        struct Node* temp=head;
        while(temp->next!=NULL && temp->next->priority>=priority){
            temp=temp->next;
        }
        newNode->next=temp->next;
        temp->next=newNode;
}
void delete(){
    if(head==NULL){
        printf("Queue is empty\n");
        return ;
    }
    struct Node* temp=head;
    printf("%d\n"head->id);
    head=head->next;
    free(temp);
}
int main(){
    int N;
    scanf("%d",&N);
    if(N<=0){
        printf("Invalid input");
        return 0;
    }
        char operation[10];
        int id,priority;
        for(int i=0;i<N;i++){
        scanf("%s",op);
        if(strcmp(op,"INSERT")==0){
            scanf("%d %d",&id,&priority);
        if(id<=0 || priority<=0){
            printf("Invalid input");
            return 0;
        }
        insert(id,priority);
        }
        else if(strcmp(op,"DELETE")==0){
            delete();
        }
        else{
            printf("Invalid input");
            return 0;
        }
    }
    return 0;
}