forked from mtarbit/Rosalind-Problems
-
Notifications
You must be signed in to change notification settings - Fork 0
/
e018-prtm.py
executable file
·63 lines (55 loc) · 1.41 KB
/
e018-prtm.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
#!/usr/bin/env python
# coding=utf-8
# Calculating Protein Mass
# ========================
#
# In a weighted alphabet, every symbol is assigned a positive real number called
# a weight. A string formed from a weighted alphabet is called a weighted
# string, and its weight is equal to the sum of the weights of its symbols.
#
# The standard weight assigned to each member of the 20-symbol amino acid
# alphabet is the monoisotopic mass of the corresponding amino acid.
#
# Given: A protein string P of length at most 1000 aa.
#
# Return: The weight of P to an accuracy of two decimal places. Consult the
# monoisotopic mass table.
#
# Sample Dataset
# --------------
# SKADYEK
#
# Sample Output
# -------------
# 821.39
MONOISOTOPIC_MASS_TABLE = {
'A': 71.03711,
'C': 103.00919,
'D': 115.02694,
'E': 129.04259,
'F': 147.06841,
'G': 57.02146,
'H': 137.05891,
'I': 113.08406,
'K': 128.09496,
'L': 113.08406,
'M': 131.04049,
'N': 114.04293,
'P': 97.05276,
'Q': 128.05858,
'R': 156.10111,
'S': 87.03203,
'T': 101.04768,
'V': 99.06841,
'W': 186.07931,
'Y': 163.06333,
}
def weight(weighted_string):
n = 0
for aa in weighted_string:
n += MONOISOTOPIC_MASS_TABLE[aa]
return n
if __name__ == "__main__":
small_dataset = "SKADYEK"
large_dataset = open('datasets/rosalind_prtm.txt').read().strip()
print weight(large_dataset)