시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 128 MB27712610949.545%

문제

대회가 끝이 나면 대부분의 참가자들은 어디서 꼬였는지에 대한 원망과 함께 좌절하게 된다.

심사위원들 또한 좌절한다. 제출 기록에 따라 각 참가자에게 점수를 매기고 순위를 산정해야 하기 때문이다.

비록 대회는 끝이 났지만 아직 코딩할 여력이 있다면, 심사위원들을 도울 순위 산정 프로그램을 만들어보자.

입력

첫 줄에 테스트 케이스의 수 K가 주어진다.

각 테스트 케이스의 첫 줄엔 세 개의 정수 M, N, P가 주어진다.

M은 대회에 사용된 문제의 개수이며 (1 ≤ M ≤ 10), N은 총 제출 수 (1 ≤ N ≤ 5000),

P는 참가자의 수 (1 ≤ P ≤ 500) 이다.

각 문제는 A, B, ... 로 이름붙여져 있으며, 참가자들은 1부터 P까지의 아이디를 갖는다.

이어 N개의 줄에 걸쳐 제출 기록의 내용이 주어진다.

제출 기록은 p m t j의 형식이며, p는 제출한 참가자(1, 2, ...) , m은 문제 번호(A, B, ..), t는 제출한 시각, j는 정답 여부이다.

j=0이라면 오답이며, j=1일 경우엔 정답이다.

제출 기록은 제출 시각이 감소하지 않는 순으로 주어진다.

문제를 맞힐 경우, 맞힌 사람은 총점에 문제를 맞힌 시각 + 그 문제를 틀린 횟수*20만큼을 더하게 된다.

만일 동일한 문제를 두 번 이상 맞히더라도 처음 맞힌 것만 인정된다.

출력

각 테스트 케이스마다 Data Set K: 를 출력한 뒤, 참가자들의 아이디, 푼 문제 수, 총점을 P줄에 걸쳐 1위부터 차례대로 출력한다.

순위는 푼 문제 수가 다르다면 푼 문제 수가 많은 사람이 높으며,

푼 문제 수가 같다면 총점이 낮은 사람이 순위가 높다.

어떤 테스트 케이스에서도 동점자가 나오는 경우는 없다.

각 테스트 케이스의 사이엔 빈 줄을 하나 출력한다.

예제 입력 1

2
4 6 3
2 C 11 0
1 B 24 1
2 C 25 1
1 C 40 0
3 D 55 1
2 B 55 1
2 8 2
1 A 8 0
2 B 11 1
1 A 11 0
1 A 14 0
1 A 20 0
2 B 22 1
2 A 23 0
1 A 24 1

예제 출력 1

Data Set 1:
2 2 100
1 1 24
3 1 55

Data Set 2:
2 1 11
1 1 104
W3sicHJvYmxlbV9pZCI6IjUxNzkiLCJwcm9ibGVtX2xhbmciOiIwIiwidGl0bGUiOiJcdWM2YjBcdWMyYjlcdWM3OTBcdWIyOTQgXHViMjA0XHVhZDZjPyIsImRlc2NyaXB0aW9uIjoiPHA+XHViMzAwXHVkNjhjXHVhYzAwIFx1YjA1ZFx1Yzc3NCBcdWIwOThcdWJhNzQgXHViMzAwXHViZDgwXHViZDg0XHVjNzU4IFx1Y2MzOFx1YWMwMFx1Yzc5MFx1YjRlNFx1Yzc0MCBcdWM1YjRcdWI1MTRcdWMxMWMgXHVhZjJjXHVjNjAwXHViMjk0XHVjOWMwXHVjNWQwIFx1YjMwMFx1ZDU1YyBcdWM2ZDBcdWI5ZGRcdWFjZmMgXHVkNTY4XHVhZWQ4IFx1Yzg4Y1x1YzgwOFx1ZDU1OFx1YWM4YyBcdWI0MWNcdWIyZTQuPFwvcD5cclxuXHJcbjxwPlx1YzJlY1x1YzBhY1x1YzcwNFx1YzZkMFx1YjRlNCBcdWI2MTBcdWQ1NWMgXHVjODhjXHVjODA4XHVkNTVjXHViMmU0LiBcdWM4MWNcdWNkOWMgXHVhZTMwXHViODVkXHVjNWQwIFx1YjUzMFx1Yjc3YyBcdWFjMDEgXHVjYzM4XHVhYzAwXHVjNzkwXHVjNWQwXHVhYzhjIFx1YzgxMFx1YzIxOFx1Yjk3YyBcdWI5ZTRcdWFlMzBcdWFjZTAgXHVjMjFjXHVjNzA0XHViOTdjIFx1YzBiMFx1YzgxNVx1ZDU3NFx1YzU3YyBcdWQ1NThcdWFlMzAgXHViNTRjXHViYjM4XHVjNzc0XHViMmU0LjxcL3A+XHJcblxyXG48cD5cdWJlNDRcdWI4NWQgXHViMzAwXHVkNjhjXHViMjk0IFx1YjA1ZFx1Yzc3NCBcdWIwYWNcdWM5YzBcdWI5Y2MgXHVjNTQ0XHVjOWMxIFx1Y2Y1NFx1YjUyOVx1ZDU2MCBcdWM1ZWNcdWI4MjVcdWM3NzQgXHVjNzg4XHViMmU0XHViYTc0LCBcdWMyZWNcdWMwYWNcdWM3MDRcdWM2ZDBcdWI0ZTRcdWM3NDQgXHViM2M0XHVjNmI4IFx1YzIxY1x1YzcwNCBcdWMwYjBcdWM4MTUgXHVkNTA0XHViODVjXHVhZGY4XHViN2E4XHVjNzQ0IFx1YjljY1x1YjRlNFx1YzViNFx1YmNmNFx1Yzc5MC48XC9wPlxyXG4iLCJpbnB1dCI6IjxwPlx1Y2NhYiBcdWM5MDRcdWM1ZDAgXHVkMTRjXHVjMmE0XHVkMmI4IFx1Y2YwMFx1Yzc3NFx1YzJhNFx1Yzc1OCBcdWMyMTggS1x1YWMwMCBcdWM4ZmNcdWM1YjRcdWM5YzRcdWIyZTQuPFwvcD5cclxuXHJcbjxwPlx1YWMwMSBcdWQxNGNcdWMyYTRcdWQyYjggXHVjZjAwXHVjNzc0XHVjMmE0XHVjNzU4IFx1Y2NhYiBcdWM5MDRcdWM1ZDQgXHVjMTM4IFx1YWMxY1x1Yzc1OCBcdWM4MTVcdWMyMTggTSwgTiwgUFx1YWMwMCBcdWM4ZmNcdWM1YjRcdWM5YzRcdWIyZTQuPFwvcD5cclxuXHJcbjxwPk1cdWM3NDAgXHViMzAwXHVkNjhjXHVjNWQwIFx1YzBhY1x1YzZhOVx1YjQxYyBcdWJiMzhcdWM4MWNcdWM3NTggXHVhYzFjXHVjMjE4XHVjNzc0XHViYTcwICgxICZsZTsgTSAmbGU7IDEwKSwgTlx1Yzc0MCBcdWNkMWQgXHVjODFjXHVjZDljIFx1YzIxOCAoMSAmbGU7IE4gJmxlOyA1MDAwKSw8XC9wPlxyXG5cclxuPHA+UFx1YjI5NCBcdWNjMzhcdWFjMDBcdWM3OTBcdWM3NTggXHVjMjE4ICgxICZsZTsgUCAmbGU7IDUwMCkgXHVjNzc0XHViMmU0LjxcL3A+XHJcblxyXG48cD5cdWFjMDEgXHViYjM4XHVjODFjXHViMjk0IEEsIEIsIC4uLiBcdWI4NWMgXHVjNzc0XHViOTg0XHViZDk5XHVjNWVjXHVjODM4IFx1Yzc4OFx1YzczY1x1YmE3MCwgXHVjYzM4XHVhYzAwXHVjNzkwXHViNGU0XHVjNzQwIDFcdWJkODBcdWQxMzAgUFx1YWU0Y1x1YzljMFx1Yzc1OCBcdWM1NDRcdWM3NzRcdWI1MTRcdWI5N2MgXHVhYzE2XHViMjk0XHViMmU0LjxcL3A+XHJcblxyXG48cD5cdWM3NzRcdWM1YjQgTlx1YWMxY1x1Yzc1OCBcdWM5MDRcdWM1ZDAgXHVhYzc4XHVjY2QwIFx1YzgxY1x1Y2Q5YyBcdWFlMzBcdWI4NWRcdWM3NTggXHViMGI0XHVjNmE5XHVjNzc0IFx1YzhmY1x1YzViNFx1YzljNFx1YjJlNC48XC9wPlxyXG5cclxuPHA+XHVjODFjXHVjZDljIFx1YWUzMFx1Yjg1ZFx1Yzc0MCBwIG0gdCBqXHVjNzU4IFx1ZDYxNVx1YzJkZFx1Yzc3NFx1YmE3MCwgcFx1YjI5NCBcdWM4MWNcdWNkOWNcdWQ1NWMgXHVjYzM4XHVhYzAwXHVjNzkwKDEsIDIsIC4uLikgLCBtXHVjNzQwIFx1YmIzOFx1YzgxYyBcdWJjODhcdWQ2MzgoQSwgQiwgLi4pLCB0XHViMjk0IFx1YzgxY1x1Y2Q5Y1x1ZDU1YyBcdWMyZGNcdWFjMDEsIGpcdWIyOTQgXHVjODE1XHViMmY1IFx1YzVlY1x1YmQ4MFx1Yzc3NFx1YjJlNC48XC9wPlxyXG5cclxuPHA+aj0wXHVjNzc0XHViNzdjXHViYTc0IFx1YzYyNFx1YjJmNVx1Yzc3NFx1YmE3MCwgaj0xXHVjNzdjIFx1YWNiZFx1YzZiMFx1YzVkNCBcdWM4MTVcdWIyZjVcdWM3NzRcdWIyZTQuPFwvcD5cclxuXHJcbjxwPlx1YzgxY1x1Y2Q5YyBcdWFlMzBcdWI4NWRcdWM3NDAgXHVjODFjXHVjZDljIFx1YzJkY1x1YWMwMVx1Yzc3NCBcdWFjMTBcdWMxOGNcdWQ1NThcdWM5YzAgXHVjNTRhXHViMjk0IFx1YzIxY1x1YzczY1x1Yjg1YyBcdWM4ZmNcdWM1YjRcdWM5YzRcdWIyZTQuPFwvcD5cclxuXHJcbjxwPlx1YmIzOFx1YzgxY1x1Yjk3YyBcdWI5ZGVcdWQ3OTAgXHVhY2JkXHVjNmIwLCBcdWI5ZGVcdWQ3OGMgXHVjMGFjXHViNzhjXHVjNzQwIFx1Y2QxZFx1YzgxMFx1YzVkMCBcdWJiMzhcdWM4MWNcdWI5N2MgXHViOWRlXHVkNzhjIFx1YzJkY1x1YWMwMSArIFx1YWRmOCBcdWJiMzhcdWM4MWNcdWI5N2MgXHVkMmMwXHViOWIwIFx1ZDY5Zlx1YzIxOCoyMFx1YjljY1x1ZDA3Y1x1Yzc0NCBcdWIzNTRcdWQ1NThcdWFjOGMgXHViNDFjXHViMmU0LjxcL3A+XHJcblxyXG48cD5cdWI5Y2NcdWM3N2MgXHViM2Q5XHVjNzdjXHVkNTVjIFx1YmIzOFx1YzgxY1x1Yjk3YyBcdWI0NTAgXHViYzg4IFx1Yzc3NFx1YzBjMSBcdWI5ZGVcdWQ3ODhcdWIzNTRcdWI3N2NcdWIzYzQgXHVjYzk4XHVjNzRjIFx1YjlkZVx1ZDc4YyBcdWFjODNcdWI5Y2MgXHVjNzc4XHVjODE1XHViNDFjXHViMmU0LjxcL3A+XHJcbiIsIm91dHB1dCI6IjxwPlx1YWMwMSBcdWQxNGNcdWMyYTRcdWQyYjggXHVjZjAwXHVjNzc0XHVjMmE0XHViOWM4XHViMmU0IERhdGEgU2V0IEs6IFx1Yjk3YyBcdWNkOWNcdWI4MjVcdWQ1NWMgXHViNGE0LCBcdWNjMzhcdWFjMDBcdWM3OTBcdWI0ZTRcdWM3NTggXHVjNTQ0XHVjNzc0XHViNTE0LCBcdWQ0N2MgXHViYjM4XHVjODFjIFx1YzIxOCwgXHVjZDFkXHVjODEwXHVjNzQ0IFBcdWM5MDRcdWM1ZDAgXHVhYzc4XHVjY2QwIDFcdWM3MDRcdWJkODBcdWQxMzAgXHVjYzI4XHViODQwXHViMzAwXHViODVjIFx1Y2Q5Y1x1YjgyNVx1ZDU1Y1x1YjJlNC48XC9wPlxyXG5cclxuPHA+XHVjMjFjXHVjNzA0XHViMjk0IFx1ZDQ3YyBcdWJiMzhcdWM4MWMgXHVjMjE4XHVhYzAwIFx1YjJlNFx1Yjk3NFx1YjJlNFx1YmE3NCBcdWQ0N2MgXHViYjM4XHVjODFjIFx1YzIxOFx1YWMwMCBcdWI5Y2VcdWM3NDAgXHVjMGFjXHViNzhjXHVjNzc0IFx1YjE5Mlx1YzczY1x1YmE3MCw8XC9wPlxyXG5cclxuPHA+XHVkNDdjIFx1YmIzOFx1YzgxYyBcdWMyMThcdWFjMDAgXHVhYzE5XHViMmU0XHViYTc0IFx1Y2QxZFx1YzgxMFx1Yzc3NCBcdWIwYWVcdWM3NDAgXHVjMGFjXHViNzhjXHVjNzc0IFx1YzIxY1x1YzcwNFx1YWMwMCBcdWIxOTJcdWIyZTQuPFwvcD5cclxuXHJcbjxwPlx1YzViNFx1YjVhNCBcdWQxNGNcdWMyYTRcdWQyYjggXHVjZjAwXHVjNzc0XHVjMmE0XHVjNWQwXHVjMTFjXHViM2M0IFx1YjNkOVx1YzgxMFx1Yzc5MFx1YWMwMCBcdWIwOThcdWM2MjRcdWIyOTQgXHVhY2JkXHVjNmIwXHViMjk0IFx1YzVjNlx1YjJlNC48XC9wPlxyXG5cclxuPHA+XHVhYzAxIFx1ZDE0Y1x1YzJhNFx1ZDJiOCBcdWNmMDBcdWM3NzRcdWMyYTRcdWM3NTggXHVjMGFjXHVjNzc0XHVjNWQ0IFx1YmU0OCBcdWM5MDRcdWM3NDQgXHVkNTU4XHViMDk4IFx1Y2Q5Y1x1YjgyNVx1ZDU1Y1x1YjJlNC48XC9wPlxyXG4iLCJoaW50IjoiIiwib3JpZ2luYWwiOiIwIiwiaHRtbF90aXRsZSI6IjAiLCJwcm9ibGVtX2xhbmdfdGNvZGUiOiJLb3JlYW4ifSx7InByb2JsZW1faWQiOiI1MTc5IiwicHJvYmxlbV9sYW5nIjoiMSIsInRpdGxlIjoiV2hvIGdldHMgdGhlIHByaXplcz8iLCJkZXNjcmlwdGlvbiI6IjxwPlRoZSBjb250ZXN0IGlzIG92ZXIsIGV2ZXJ5Ym9keSBpcyBkaXNhcHBvaW50ZWQgYXQgaGF2aW5nIHNjcmV3ZWQgc29tZXRoaW5nIHVwLCBhbmQgbm93LCB0aGUganVkZ2VzIGhhdmUgdG8gbG9vayBhdCBodW5kcmVkcyBvZiBzb2x1dGlvbnMsIGNvcnJlY3QgYW5kIGluY29ycmVjdCwgYW5kIGRldGVybWluZSB3aG8gaGFzIHdvbi4gSG93IHRoZXkgd2lzaCB0aGV5IGhhZCBhIHByb2dyYW0gdG8gZG8gdGhhdCE8XC9wPlxyXG5cclxuPHA+SnVkZ2luZyB3aWxsIGdvIGV4YWN0bHkgYnkgdGhlIHJ1bGVzIG9mIHRoZSBjb250ZXN0ICZtZGFzaDsgaWYgeW91IGFyZSBub3Qgc3VyZSBhYm91dCB0aGUgZXhhY3QgcnVsZXMsIHlvdSBzaG91bGQgbG9vayB0aGVtIHVwIG9uIHRoZSAmbGRxdW87cnVsZXMmcmRxdW87IGhhbmRvdXQgdGhhdCB5b3UgcmVjZWl2ZWQuIFlvdSBjYW4gYXNzdW1lIHRoYXQgaW4gYWxsIG91ciB0ZXN0IGNhc2VzLCBubyB0d28gcGFydGljaXBhbnRzIHdpbGwgc2ltdWx0YW5lb3VzbHkgaGF2ZSB0aGUgZXhhY3Qgc2FtZSBudW1iZXIgb2YgcHJvYmxlbXMgc29sdmVkIGFuZCBleGFjdCBzYW1lIHRvdGFsIHRpbWUuPFwvcD5cclxuIiwiaW5wdXQiOiI8cD5UaGUgZmlyc3QgbGluZSBpcyB0aGUgbnVtYmVyIEsgb2YgaW5wdXQgZGF0YSBzZXRzLCBmb2xsb3dlZCBieSB0aGUgSyBkYXRhIHNldHMsIGVhY2ggb2YgdGhlIGZvbGxvd2luZyBmb3JtOjxcL3A+XHJcblxyXG48cD5UaGUgZmlyc3QgbGluZSBjb250YWlucyB0aHJlZSBudW1iZXIsIE0sIE4sIGFuZCBQLiBNIGlzIHRoZSBudW1iZXIgb2YgcHJvYmxlbXMgKDEgJmxlOyBNICZsZTsgMTApLCBOIGlzIHRoZSB0b3RhbCBudW1iZXIgb2Ygc3VibWlzc2lvbnMgKDEgJmxlOyBOICZsZTsgNTAwMCksIGFuZCBQIGlzIHRoZSBudW1iZXIgb2YgcGFydGljaXBhbnRzICgxICZsZTsgUCAmbGU7IDUwMCkuIFRoZSBwcm9ibGVtcyBhcmUgbnVtYmVyZWQgQSwgQiwgLiAuIC4sIHBhcnRpY2lwYW50cyBhcmUgbnVtYmVyZWQgMSwgLiAuIC4gLCBQLjxcL3A+XHJcblxyXG48cD5UaGlzIGxpbmUgaXMgZm9sbG93ZWQgYnkgTiBsaW5lcywgZWFjaCBkZXNjcmliaW5nIG9uZSBzdWJtaXNzaW9uLiBFYWNoIGxpbmUgaXMgb2YgdGhlIGZvcm0gJmxkcXVvO3AgbSB0IGomcmRxdW87LiBIZXJlLCBwIGlzIHRoZSBudW1iZXIgb2YgdGhlIHN1Ym1pdHRpbmcgcGFydGljaXBhbnQsIG0gdGhlIGlkZW50aWZpY2F0aW9uIGxldHRlciBvZiB0aGUgcHJvYmxlbSAoaS5lLiBBLCBCLCBhbmQgc28gb24pLCB0IHRoZSB0aW1lIChpbiBtaW51dGVzIGludG8gdGhlIGNvbnRlc3QpIGF0IHdoaWNoIHRoZSBzdWJtaXNzaW9uIHRvb2sgcGxhY2UsIGFuZCBqIHRoZSBqdWRnbWVudCwgYSAxIGZvciBhIGNvcnJlY3Qgc3VibWlzc2lvbiwgYW5kIGEgMCBmb3IgYW4gaW5jb3JyZWN0IG9uZS4gVGhlIGxpbmVzIHdpbGwgYmUgc29ydGVkIGJ5IG5vbi1kZWNyZWFzaW5nIHN1Ym1pc3Npb24gdGltZXMuPFwvcD5cclxuIiwib3V0cHV0IjoiPHA+VGhlIG91dHB1dCBmb3IgYSBkYXRhIHNldCBpcyB0aGUgbnVtYmVyIG9mIHRoZSBkYXRhIHNldCwgYW5kIHRoZSBsaXN0IG9mIGFsbCBwYXJ0aWNpcGFudHMgc29ydGVkIGFjY29yZGluZyB0byB0aGVpciByYW5raW5nLiBGb3IgZWFjaCBwYXJ0aWNpcGFudCwgaXQgc2hvdWxkIGxpc3QgdGhlIG51bWJlciBvZiBwcm9ibGVtcyBzb2x2ZWQgYW5kIHRoZSB0b3RhbCB0aW1lIChpbmNsdWRpbmcgcGVuYWx0aWVzKS4gVGhlIG91dHB1dCBmb3IgZGlmZmVyZW50IGRhdGEgc2V0cyBzaG91bGQgYmUgc2VwYXJhdGVkIGJ5IGFuIGVtcHR5IGxpbmUuPFwvcD5cclxuIiwiaGludCI6IiIsIm9yaWdpbmFsIjoiMSIsImh0bWxfdGl0bGUiOiIwIiwicHJvYmxlbV9sYW5nX3Rjb2RlIjoiRW5nbGlzaCJ9XQ==