diff options
author | RossTheRoss <msattr@gmail.com> | 2020-02-09 08:46:52 -0600 |
---|---|---|
committer | RossTheRoss <msattr@gmail.com> | 2020-02-09 08:46:52 -0600 |
commit | bd1d350c376b45e334697851e29b2f79fee0c956 (patch) | |
tree | eb242032a64442caef7a35434400eb0818911e9a /csci4041/MergeSortPy.py | |
parent | Do micro prelab (diff) | |
parent | Rename file (diff) | |
download | homework-bd1d350c376b45e334697851e29b2f79fee0c956.tar homework-bd1d350c376b45e334697851e29b2f79fee0c956.tar.gz homework-bd1d350c376b45e334697851e29b2f79fee0c956.tar.bz2 homework-bd1d350c376b45e334697851e29b2f79fee0c956.tar.lz homework-bd1d350c376b45e334697851e29b2f79fee0c956.tar.xz homework-bd1d350c376b45e334697851e29b2f79fee0c956.tar.zst homework-bd1d350c376b45e334697851e29b2f79fee0c956.zip |
Merge branch 'master' of github.com:RosstheRoss/TestingFun
Diffstat (limited to 'csci4041/MergeSortPy.py')
-rw-r--r-- | csci4041/MergeSortPy.py | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/csci4041/MergeSortPy.py b/csci4041/MergeSortPy.py new file mode 100644 index 0000000..bc9ae7d --- /dev/null +++ b/csci4041/MergeSortPy.py @@ -0,0 +1,30 @@ +def head(Q): + return Q[0] +def tail(Q): + return Q[1:] +def mergesort(U): + if U == [] or tail(U) == []: + return U + else: + L = [] + R = [] + while U != [] and tail(U) != []: + L = L+[head(U)] + U = tail(U) + R = R+[head(U)] + U = tail(U) + L = L + U + L = mergesort(L) + R = mergesort(R) + s = [] + while L != [] and R != []: + if head(L) <= head(R): + s = s + [head(L)] + L = tail(L) + else: + s = s + [head(R)] + R = tail(R) + s = s + L + R + return s + +print(mergesort([9,3,7,5,6,4,8,2]))
\ No newline at end of file |