Your mission in this problem is to write a program which, given the submission log of an ICPC (International Collegiate Programming Contest), determines team rankings.

The log is a sequence of records of program submission in the order of submission. A record has four fields: elapsed time, team number, problem number, and judgment. The elapsed time is the time elapsed from the beginning of the contest to the submission. The judgment field tells whether the submitted program was correct or incorrect, and when incorrect, what kind of an error was found.

The team ranking is determined according to the following rules. Note that the rule set shown here is one used in the real ICPC World Finals and Regionals, with some detail rules omitted for simplification.

- Teams that solved more problems are ranked higher.
- Among teams that solve the same number of problems, ones with smaller total consumed time are ranked higher.
- If two or more teams solved the same number of problems, and their total consumed times are the same, they are ranked the same.

The total consumed time is the sum of the consumed time for each problem solved. The consumed time for a solved problem is the elapsed time of the accepted submission plus 20 penalty minutes for every previously rejected submission for that problem.

If a team did not solve a problem, the consumed time for the problem is zero, and thus even if there are several incorrect submissions, no penalty is given.

You can assume that a team never submits a program for a problem after the correct submission for the same problem.

The input is a sequence of datasets each in the following format. The last dataset is followed by a line with four zeros.

MTPR

m_{1}t_{1}p_{1}j_{1}

m_{2}t_{2}p_{2}j_{2}

.....

m_{R}t_{R}p_{R}j_{R}

The first line of a dataset contains four integers
*M*, *T*, *P*, and *R*.
*M* is the duration of the contest.
*T* is the number of teams.
*P* is the number of problems.
*R* is the number of submission records.
The relations
120 ≤ *M* ≤ 300,
1 ≤ *T* ≤ 50,
1 ≤ *P* ≤ 10,
and 0 ≤ *R* ≤ 2000
hold for these values.
Each team is assigned a team number between 1 and *T*, inclusive.
Each problem is assigned a problem number between 1 and *P*, inclusive.

Each of the following *R* lines contains a submission record
with four integers
*m _{k}*,

The elapsed time fields are rounded off to the nearest minute.

Submission records are given in the order of submission.
Therefore, if *i* < *j*,
the *i*-th submission is done before the *j*-th submission
(*m _{i}* ≤

For each dataset, your program should output team numbers (from 1 to *T*),
higher ranked teams first.
The separator between two team numbers should be a comma.
When two teams are ranked the same, the separator between them
should be an equal sign.
Teams ranked the same should be listed
in decreasing order of their team numbers.

300 10 8 5 50 5 2 1 70 5 2 0 75 1 1 0 100 3 1 0 150 3 2 0 240 5 5 7 50 1 1 0 60 2 2 0 70 2 3 0 90 1 3 0 120 3 5 0 140 4 1 0 150 2 4 1 180 3 5 4 15 2 2 1 20 2 2 1 25 2 2 0 60 1 1 0 120 5 5 4 15 5 4 1 20 5 4 0 40 1 1 0 40 2 2 0 120 2 3 4 30 1 1 0 40 2 1 0 50 2 2 0 60 1 2 0 120 3 3 2 0 1 1 0 1 2 2 0 300 5 8 0 0 0 0 0

3,1,5,10=9=8=7=6=4=2 2,1,3,4,5 1,2,3 5=2=1,4=3 2=1 1,2,3 5=4=3=2=1

Source: ACM International Collegiate Programming Contest
, Japan Domestic Contest, Aizu, Japan, 2013-07-12

http://sparth.u-aizu.ac.jp/icpc2013/

http://sparth.u-aizu.ac.jp/icpc2013/