# Definition number 1 1
void main()
{ int i,j;
Structural team {int win
Int loss;
Int score;
Int symbol;
};
int n,m,k,a,b,c;
while(scanf("%d%d ",& ampn & amp; m)! =EOF)
{ if(n = = 0 & amp; & ampm==0) disconnect;
struct tea[N]= { {0,0,0,0},{0,0,0, 1},{ 0,0,0,0,2},
{0,0,0,3},{0,0,0,4},{0,0,0,5},
{0,0,0,6},{0,0,0,7},{0,0,0,8},
{0,0,0,9},{0,0,0, 10}};
Structural team t;
while(m -)
{scanf("%d%d%d ",& i, & ampb & amp;; c);
if(c== 1)
Tea [a]. Score = 3+ tea [a]. Scores; //Calculate the total score
Tea [b]. Score = 0+ tea [b]. Scores;
Tea [a]. Win = 1+ tea [a]. Win;
Tea [b]. Loss = 1+ tea [b]. Loss;
}
if(c==- 1)
Tea [a]. Score =- 1+ tea [a]. Scores; //You said
Tea [b]. Score = 3+ tea [b]. Scores;
Tea [a]. Loss = 1+ tea [a]. Loss;
Tea [b]. Win = 1+ tea [b]. Win;
}
If (c==0)
Tea [a]. Score = 1+ tea [a]. Scores;
Tea [b]. Score = 1+ tea [b]. Scores;
}
}
//for(I = 1; I < = n; I++) here represents the score of each team, the number of wins and the number of losses.
// printf("%d %d %d %d\n ",I,tea[i]。 Scores, tea [me]. Win, tea [me]. Loss);
k = n;
for(j = 1; j & ltn; j++,k -)
for(I = 1; I & ltk;; i++)
{if (tea [i+ 1]. Score & lt tea [me]. score){ t = tea[I]; //The team with high points is behind.
Tea [I]= tea [I+1];
tea[I+ 1]= t;
}
Else if (tea [me]. Score = = tea [i]. Score) {if (tea [i]. Win> tea [i+ 1]. win){ t = tea[I]; //The team with the same score and more wins is behind.
Tea [I]= tea [I+1];
tea[I+ 1]= t;
}
Else if (tea [me]. win==tea[i+ 1]。 Win) {If (tea [me]. Loss of< tea [i+ 1]. loss){ t = tea[I]; //The team with the same score and the same victory is ranked behind with fewer negative games.
Tea [I]= tea [I+1];
tea[I+ 1]= t;
}
Else if (tea [me]. Loss = = tea [i+ 1]. Loss) {if (tea [i]. Signature & lt Tea [i+ 1]. sign){ t = tea[I]; //If you can't tell the order, the smallest number comes last.
Tea [I]= tea [I+1];
tea[I+ 1]= t;
}
}
}
}
}
for(I = n; I> 1; I-)// output printing
printf("%d %d ",tea[i]。 Sign, tea [me]. Score);
printf("%d %d ",tea[i]。 Sign, tea [me]. Score);
printf(" \ n ");
}
}