#include <stdio.h>
#include <string.h>

typedef struct {
    int empId;
    char name[10];
    int age;
} Employee ;
Employee employeeArray[30];

//数据输入
void dataIn(){
    int i = 0, j = 0,id,age,cnt=0;
    char name[10]={'\0'};
    while(scanf("%d %s %d",&id,name,&age)!=EOF ){
        //printf("%d %s %d\n",id,name,age);
        employeeArray[cnt].empId=id;
        employeeArray[cnt].age=age;
        strcpy(employeeArray[cnt].name, name);
        cnt++;
        memset(name, 0, sizeof name);
    }
}

//j与j+1员工信息互换
void swap(int j) {
    int empId = 0, age = 0;
    char name[10] = {'\0'};
    empId = employeeArray[j + 1].empId;
    age = employeeArray[j + 1].age;
    strcpy(name, employeeArray[j + 1].name);
    employeeArray[j + 1].empId = employeeArray[j].empId;
    employeeArray[j + 1].age = employeeArray[j].age;
    strcpy(employeeArray[j + 1].name, employeeArray[j].name);

    employeeArray[j].empId = empId;
    employeeArray[j].age = age;
    strcpy(employeeArray[j].name, name);
}

int main() {
    int n,i,j;
    scanf("%d ", &n);
    //char data[n][100];
    
    dataIn();

    // while (gets(data[i])) {
    //     //printf("%s\n", data[i]);
    //     cnt = 1;
    //     idOrAge = 0;
    //     nameSize = 0;
    //     memset(name, 0, sizeof name);
    //     for (j = 0; j <= strlen(data[i]); j++) {
    //         if (data[i][j] == ' ' || j == strlen(data[i])) {
    //             if (cnt == 1) {
    //                 employeeArray[i].empId = idOrAge;
    //                 idOrAge = 0;
    //                 cnt++;
    //                 continue;
    //             }
    //             if (cnt == 2) {
    //                 strcpy(employeeArray[i].name, name);
    //                 cnt++;
    //                 continue;
    //             }
    //             if (cnt == 3) {
    //                 employeeArray[i].age = idOrAge;
    //                 break;
    //             }
    //         }
    //         if (cnt == 1 || cnt == 3) {
    //             idOrAge = idOrAge * 10 + data[i][j] - '0';
    //         }
    //         if (cnt == 2) {
    //             name[nameSize++] = data[i][j];
    //         }
    //     }
    //     i++;
    // }


    // //输出结构体数组
    // for (i = 0; i < n; i++) {
    //     printf("%d %s %d\n", employeeArray[i].empId, employeeArray[i].name,
    //            employeeArray[i].age);
    // }

    //排序后输出最后三个职工信息
    //先按姓名排序,再按工号,最后按年龄排序
    for (i = 0; i < n - 1; i++) {
        for (j = 0; j < n - 1 - i; j++) {
            if (strcmp(employeeArray[j].name, employeeArray[j + 1].name) > 0) {
                //前者的名字更大,后移
                swap(j);
            }
        }
    }

    //按工号排序
    for (i = 0; i < n - 1; i++) {
        for (j = 0; j < n - 1 - i; j++) {
            if (employeeArray[j].empId > employeeArray[j + 1].empId) {
                //前者的工号更大,后移
                swap(j);
            }
        }
    }

    //按年龄排序
    for (i = 0; i < n - 1; i++) {
        for (j = 0; j < n - 1 - i; j++) {
            if (employeeArray[j].age > employeeArray[j + 1].age) {
                //前者的年龄更大,后移
                swap(j);
            }
        }
    }

    //输出结构体数组
    for (i = 0; i < 3; i++) {
        printf("%d %s %d\n", employeeArray[i].empId, employeeArray[i].name,
               employeeArray[i].age);
    }

    return 0;
}