Hide

Problem D
Music Your Way

MyTunes, a new music application from Mapple, allows you to display and sort your music according to many different attributes. Attributes like album name, song title, artist, and song length are available, among others. One feature MyTunes does NOT have is stable sorting. You need to write the software which does this. Stable sorting would allow the user to do something like this: first sort the whole list by song title, and then sort the whole list by artist. The result is that the list of songs are sorted primarily by artist (since it’s the last thing used to sort), then within each artist they are sorted by song name (since before the artist sort, the songs were ordered by song name). When sorting two songs with equal attribute values they should remain in their relative order prior to sorting (giving stable sorting).

The first sort starts from the order of songs as given in the input. Each subsequent sort starts from the order given by the previous sort, rather than starting from the initial order. All sorting should be done least to greatest, in lexicographic order (using ASCII values, even for numeric data).

Input

The first line contains a list of $1$ to $20$ unique attributes, separated by single spaces. The next line contains an integer $1 \leq m \leq 100$ giving the number of songs that follow, one song per line. Each song has the values for all the attributes, separated by single spaces. The next line contains an integer $1 \leq n \leq 20$ giving the number of sorting commands. The following $n$ lines each contain one sort command, which is the name of an attribute. Initially, the song list is in the order given on the input. All attributes and values are between $1$ and $30$ characters, using only a–z, A–Z, $0$$9$, and underscore (_).

Output

After each sort command, print the list of attributes followed by the song list in the order given by the sort command, one song per line. Print a space between adjacent fields. Between each pair of printed lists, print a blank line.

Sample Input 1 Sample Output 1
Artist Album Song_Title Length_seconds
5
Tchaikovsky Piano_Favorites November 163
James_Taylor Dad_Loves_His_Work Hard_Times 192
James_Taylor Dad_Loves_His_Work London_Town 236
James_Taylor Dad_Loves_His_Work Summers_Here 163
George_Winston Summer Lullaby 215
3
Artist
Album
Song_Title
Artist Album Song_Title Length_seconds
George_Winston Summer Lullaby 215
James_Taylor Dad_Loves_His_Work Hard_Times 192
James_Taylor Dad_Loves_His_Work London_Town 236
James_Taylor Dad_Loves_His_Work Summers_Here 163
Tchaikovsky Piano_Favorites November 163

Artist Album Song_Title Length_seconds
James_Taylor Dad_Loves_His_Work Hard_Times 192
James_Taylor Dad_Loves_His_Work London_Town 236
James_Taylor Dad_Loves_His_Work Summers_Here 163
Tchaikovsky Piano_Favorites November 163
George_Winston Summer Lullaby 215

Artist Album Song_Title Length_seconds
James_Taylor Dad_Loves_His_Work Hard_Times 192
James_Taylor Dad_Loves_His_Work London_Town 236
George_Winston Summer Lullaby 215
Tchaikovsky Piano_Favorites November 163
James_Taylor Dad_Loves_His_Work Summers_Here 163
Sample Input 2 Sample Output 2
Artist_Name Song
2
Chopin Scherzo_no_1_in_B_minor
Chopin Polonaise_no_3_in_A
2
Artist_Name
Song
Artist_Name Song
Chopin Scherzo_no_1_in_B_minor
Chopin Polonaise_no_3_in_A

Artist_Name Song
Chopin Polonaise_no_3_in_A
Chopin Scherzo_no_1_in_B_minor

Please log in to submit a solution to this problem

Log in