A higher resolution is required to access the IDE
- 28
Learning Opportunities
This puzzle can be solved using the following concepts. Practice using these concepts and improve your skills.
Statement
Goal
Your goal is to translate a genetic code into sequences of amino acids.Let's name a triplet of characters in
You will be given n lines, each consisting of a string rna, and a codon_table in the stub comments. The codon_table contains every codon and their corresponding amino acid.
There are three possible translations. The translation process, for each of the three starting indices of rna:
0. Start in CLOSED state.
1. If in CLOSED state and the current codon is a start codon, transition to OPENED.
2. If in OPENED state and the current codon is a stop codon, transition to CLOSED and store the current sequence.
3. If in OPENED state, add the current amino acid from codon_table to the back of the current sequence.
4. Move
5. Repeat steps 1-4 until the entire rna string is translated.
Note that the sequences are only stored when scanning a stop codon (step 2). That implies that if, for a given index, the translation process terminates in an OPENED state, the current sequence is lost.
For all three starting indices return the translation that yields the most amino acids. If that translation consists of multiple sequences, return them joined by a
Example:
CCAUGCCCUAACCCA
--- | | | # (AUG) start codon: start (sequence = M).
--- | | # (CCC) not a stop codon (sequence = MP).
--- | # (UAA) is a stop codon, store sequence.
--- # (CCC) not a start codon: ignore.
Starting at index 0 or 1 yields no sequences.
The answer is just one sequence: MP, obtained for index 2.
NOTES:
- The given codon table follows the usual conventions and can be found here:
- More detailed description:
- The cover picture is from:
Input
STUB: The codon_table, with every codon and their corresponding amino acid.
Line 1: An integer n for the number of strings. Each string is a separate case.
Next n lines: A string rna of characters inAUCG .
Line 1: An integer n for the number of strings. Each string is a separate case.
Next n lines: A string rna of characters in
Output
n lines: The translated rna strings.
Constraints
For each rna string a (non empty) solution exists and is guaranteed to be unique.
Example
Input
6 AUGUAA CAUGUAA CCAUGUAA CCAUGCCCUAA CCAUGCCCUAAC CCAUGCCCUAACC
Output
M M M MP MP MP
A higher resolution is required to access the IDE