import std.algorithm; import std.array; import std.conv; import std.math; import std.stdio; import std.string; import std.range; int readint() { return readln.chomp.to!int; } int[] readints() { return readln.split.map!(to!int).array; } void calc(string[] ss) { int suit(char c) { return cast(int) "DCHS".indexOf(c); } int rank(char c) { switch (c) { case 'A': return 1; case 'T': return 10; case 'J': return 11; case 'Q': return 12; case 'K': return 13; default: return c - '0'; } } bool cmp(string a, string b) { int asuit = suit(a[0]); int bsuit = suit(b[0]); if (asuit == bsuit) { return rank(a[1]) < rank(b[1]); } return asuit < bsuit; } ss.sort!cmp; auto s = ss.join(" "); writeln(s); } void main() { readint(); auto ss = readln.split.array; calc(ss); }