#include <iostream>
#include <vector>
using namespace std;
const int N = 100010;
int n;
int e[N], ne[N], h;
bool st[N];
vector<int> a, b;
int main()
{
cin >> h >> n;
while(n --)
{
int add, data, next;
cin >> add >> data >> next;
e[add] = data, ne[add] = next;
}
for(int i = h; ~i; i = ne[i])
{
if(st[abs(e[i])] == false)
{
st[abs(e[i])] = true;
a.push_back(i);
}
else b.push_back(i);
}
for(int i = 0; i < a.size(); i++)
{
if(i == a.size() - 1)
{
printf("%05d %d -1\n", a[i], e[a[i]]);
break;
}
printf("%05d %d %05d\n", a[i], e[a[i]], a[i+1]);
}
for(int i = 0; i < b.size(); i++)
{
if(i == b.size() - 1)
{
printf("%05d %d -1\n", b[i], e[b[i]]);
break;
}
printf("%05d %d %05d\n", b[i], e[b[i]], b[i+1]);
}
}