
ZOJ Problem Set  2409
The following card trick is performed by a Magician and her Assistant. The Assistant asks a member of the audience to choose 5 cards from a standard deck of 52 cards (A, 2, 3, 4, 5, 6, 7, 8, 9, 10, J, Q, K of C[lubs], D[iamonds], H[earts] and S[pades]). The Assistant returns one of the cards to the audience member and then hands the remaining cards to the Magician, one at a time. After suitable mumbojumbo, the Magician identifies the (fifth) card held by the audience member. The Magician determines the card as follows: The order of the cards in the deck is determined first by the value and for cards of the same value by the suit (both in the order given above). So the total order of cards is: AC, AD, AH, AS, 2D, ... , KH, KS
For example: QH, 10D, 10C, 4D Smallest of the last 3 cards is 4D in place 3. 10D and 10C are out of order so add 3 + 3 to Q. Wrapping around the missing card is 5H. This problem is to write a program to perform the function of the Assistant. Input The first line of the input consists of a positive integer n, which is the number of datasets that follow. Each of the n following lines contain one data set. The dataset is a sequence of 5 cards separated by a space. Each card is given by a one or two character value and a one character suit as described in the first paragraph. Output For each dataset, the output on separate lines is an ordering of the 5 input cards as shown in the sample output. The first card in the sequence is the card to be returned to the audience member. The remaining cards are those given to the Magician (in the order given to the Magician). There may be more than one solution to some problems (but that is not to say there *will* be). In cases such as these, output the smallest one, determine the order base at the order of cards given above. For instance 10D 4D QH 10C 5H is also a solution to the first problem below but 5H QH 10D 10C 4D < 10D 4D QH 10C 5H. Sample Input
2 Sample Output
Problem 1: 5H QH 10D 10C 4D Source: Pacific Northwest 2004 