Scientists measure how closely related a species is by looking at the DNA sequences for key proteins and seeing how similar/dissimilar they are. If the two sequences of DNA are essentially the same, the two species are considered to be evolutionarily closer since there is a relationship between changes and time. This process is called sequence alignment.
Consider the two strings of DNA below:
1: AATAACGAAA
2: AAAACGAAAA
A scientist can change the alignment by assuming that an insertion or deletion, of one of the bases has occurred. They could make such a change, called an indel for short, to see if it improves the alignment:
Species 1: AATAACGAAA-
Species 2: AA-AACGAAAA
Assuming two indels, marked as two dashes(-), the alignment is greatly improved. The scientist would assume that two changes happened, one change in each species.
While complex algorithms exist to do sequence alignment, it is also useful to support a researcher and allow them to do an alignment by hand.
1. You will prompt for two strings. The strings can have any characters you like, but to be "biological" it should consist of: "A", "T", "C", "G". The strings do not have to be of the same length.
2. You will then prompt for one of 3 commands:
a. "a" for add. Add an indel
b. "d" for delete. Delete an indel
c. "s" for score. Score the present alignment
d. "q" for quit. Stop the process.
3. Adding an Indel. When you add an indel, you must prompt for two pieces of information:
a. which string to change
b. at what index (starting at 0) do you wish to place the indel (placement is before
the given index, Error if the index is out of range).
The string should then be modified and a dash(-) added.
4. Delete an Indel: If you can add an indel, you should be able to delete it if it doesn't do what you want. Again, you must prompt for two pieces of information
a. which string to change
b. the index (starting at 0) to delete the indel. It is an Error to delete a character
that is not an indel.
5. Scoring. You will report the number of matches and the number of mismatches.
a. Any indel is automatically a mismatch.
b. If one string is shorter than the other, the shorter string is filled out with indels.
c. After you score, you print both strings.
i. Matching characters are printed in lower case. If the user entered upper case letters, you convert them to lower case on a match.
ii. All mismatches are printed in upper case.
iii. Indels are printed as dashes.
Hello. I've been programming with Python for several years now, both in a professional setting and as a hobby. I've had university courses with it, as well as finished some online courses on [login to view URL] (e.g. Algorithm Design, Stanford university) using this language.
Yesterday I did a task similar to yours, you can look up my profile to see the review I got.
And my work is dirt cheap because I want to build up a reputation first, so that I could get bigger projects more easily in the future. Doesn't this sound like a good deal?
$10 USD em 1 dia
5,0 (3 avaliações)
1,0
1,0
4 freelancers estão ofertando em média $16 USD for esse trabalho