-
Notifications
You must be signed in to change notification settings - Fork 35
/
Copy pathMED.py
62 lines (55 loc) · 1.88 KB
/
MED.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
# Copyright (C) 2017 Greenweaves Software Pty Ltd
# This is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
# This software is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>
import random
def selection(A,k):
def split(v):
prefix=[]
suffix=[]
mid=[]
for a in A:
if a<v:
prefix.append(a)
elif a==v:
mid.append(a)
else:
suffix.append(a)
return (prefix,mid,suffix)
v=random.choice(A)
(prefix,mid,suffix)=split(v)
if k<=len(prefix):
return selection(prefix,k)
elif len(prefix)<k and k<=len(prefix)+len(mid):
return v
else:
return selection(suffix, k-len(prefix)-len(mid))
#print (selection([2, 36, 5, 21, 8, 13, 11, 20, 5, 4 ,1],8))
if __name__=='__main__':
import timeit
start_time = timeit.default_timer()
with open('c:/Users/Weka/Downloads/rosalind_med(1).txt') as f:
n=0
A=[]
k=0
i=0
for line in f:
text=line.strip()
if i==0:
n=int(text)
elif i==1:
A=[int(t) for t in text.split(' ')]
elif i==2:
k=int(text)
i+=1
print('n={0},k={1}'.format(n,k))
print (selection(A,k))
print ('Elapsed: {0} seconds'.format(timeit.default_timer() - start_time))