#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
using namespace std;
const int maxn=100010;
struct Student{
int id;
int de;
int cai;
int total;
int flag;
}stu[maxn];
bool cmp(Student a,Student b){
if(a.flag!=b.flag) return a.flag<b.flag;
else if(a.total!=b.total) return a.total>b.total;
else if(a.de!=b.de) return a.de>b.de;
else return a.id<b.id;
}
int main()
{
int N,L,H,index=0;
scanf("%d%d%d",&N,&L,&H);
for(int i=0;i<N;i++){
int id,de,cai;
scanf("%d%d%d",&id,&de,&cai);
if(de>=L && cai>=L){
stu[index].id=id;
stu[index].de=de;
stu[index].cai=cai;
stu[index].total=de+cai;
if(de>=H && cai>=H) stu[index].flag=1;
else if(de>=H) stu[index].flag=2;
else if(de>=cai) stu[index].flag=3;
else stu[index].flag=4;
index++;
}
}
printf("%d\n",index);
sort(stu,stu+index,cmp);
for(int i=0;i<index;i++){
printf("%d %d %d\n",stu[i].id,stu[i].de,stu[i].cai);
}
return 0;
}