码迷,mamicode.com
首页 > 编程语言 > 详细

[building block] merge sort @ Python

时间:2014-09-18 11:17:13      阅读:165      评论:0      收藏:0      [点我收藏+]

标签:style   blog   color   io   ar   for   div   sp   log   

Here is the basic algorithm about merge sort:

def merge(s1,s2,s):
    i=j=0
    while i + j < len(s):
        if j == len(s2) or (i < len(s1) and s1[i] < s2[j]):
            s[i + j] = s1[i]
            i += 1
        else:
            s[i + j] = s2[j]    
            j += 1
           
def merge_sort(s):
    """ Sort the elements of python list s using merge-sort algorithm"""
    # Time compelxity: O(nlogn), where n = len(s)
    n = len(s)
    if n < 2:
        return
    # Divide
    mid = n // 2
    s1 = s[:mid]
    s2 = s[mid:]    
    
    #conquer (with recursion)
    merge_sort(s1)
    merge_sort(s2)
    
    # merge results
    merge(s1,s2,s)
        

 

insertion sort: time complexity: O(n^2)

def insertion_sort(A):
    ”””Sort list of comparable elements into nondecreasing order.”””
    for k in range(1, len(A)): # from 1 to n-1
        cur = A[k] # current element to be inserted
        j = k # find correct index j for current
        while j > 0 and A[j-1] > cur: # element A[j-1] must be after current
            A[j] = A[j-1]
            j -= 1
        A[j] = cur # cur is now in the right place

 

[building block] merge sort @ Python

标签:style   blog   color   io   ar   for   div   sp   log   

原文地址:http://www.cnblogs.com/asrman/p/3978677.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!