#include <cstdio>
#include <algorithm>
using namespace std;
const int maxn = 100010;
// 一、定义静态链表
struct Node {
int add, data, next;
int order;
}node[maxn];
bool cmp(Node a, Node b) {
return a.order < b.order;
}
int main() {
// 二、初始化
for (int i = 0; i < maxn; i++) {
node[i].order = maxn;
}
// 录入结点信息
int begin, n, k, add;
scanf("%d%d%d", &begin, &n, &k);
for (int i = 0; i < n; i++) {
scanf("%d", &add);
scanf("%d %d", &node[add].data, &node[add].next);
node[add].add = add;
}
// 三、遍历链表
int cnt = 0;
for (int p = begin; p != -1; p = node[p].next) {
node[p].order = cnt++;
}
// 四、排序
sort(node, node + maxn, cmp);
// 五、输出
for (int i = n / k; i >= 0; i--) {
// 如果都是完整快
if (n % k == 0) {
for (int j = i * k; j <= (i + 1)*k - 1; j++) {
printf("%05d %d %05d\n", node[j].add, node[j].data, node[j].next);
}
}
// 如果最后一个不是完整块
else {
// 先输出最后一个块
int last = n % k;
for (int j = cnt - last; j < cnt; j++) {
printf("%05d %d %05d\n", node[j].add, node[j].data, node[j].next);
}
// 输出其他快
for (int j = (i - 1)*k; j <= i * k - 1; j++) {
printf("%05d %d %05d\n", node[j].add, node[j].data, node[j].next);
}
}
}
return 0;
}