forked from xuyk/Rosalind
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path051_SETO.py
33 lines (29 loc) · 1.21 KB
/
051_SETO.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
#!/usr/bin/env python
'''
A solution to a ROSALIND bioinformatics problem.
Problem Title: Introduction to Set Operations
Rosalind ID: SETO
Rosalind #: 051
URL: http://rosalind.info/problems/seto/
'''
# This problem is straight forward as Python has a Set data type with all the necessary operations built in.
# No need to reinvent the wheel for now. Maybe in the future I'll build this from scratch...
with open('data/rosalind_seto.txt') as input_data:
S, A, B = input_data.readlines()
# Convert to sets.
S = set( [i for i in xrange(1,int(S.strip())+1)] )
A = set(map(int, A.strip().rstrip('}').lstrip('{').replace(' ', '').split(',')))
B = set(map(int, B.strip().rstrip('}').lstrip('{').replace(' ', '').split(',')))
with open('output/051_SETO.txt', 'w') as output_data:
# A union B
output_data.write('{'+', '.join(map(str,list(A|B)))+'}'+'\n')
# A interset B
output_data.write('{'+', '.join(map(str,list(A&B)))+'}'+'\n')
# A - B
output_data.write('{'+', '.join(map(str,list(A-B)))+'}'+'\n')
# B - A
output_data.write('{'+', '.join(map(str,list(B-A)))+'}'+'\n')
# A Complement
output_data.write('{'+', '.join(map(str,list(S-A)))+'}'+'\n')
# B Complement
output_data.write('{'+', '.join(map(str,list(S-B)))+'}')