代码拉取完成,页面将自动刷新
# merge sort
lst = [] # declaring list l
n = int(input("Enter number of elements in the list: ")) # taking value from user
for i in range(n):
temp = int(input("Enter element" + str(i + 1) + ': '))
lst.append( temp )
def merge( ori_lst, left, mid, right ):
L, R = [], [] # PREPARE TWO TEMPORARY LIST TO HOLD ELEMENTS
for i in range( left, mid ): # LOADING
L.append( ori_lst[i] )
for i in range( mid, right ): # LOADING
R.append( ori_lst[i] )
base = left # FILL ELEMENTS BACK TO ORIGINAL LIST START FROM INDEX LEFT
# EVERY LOOP CHOOSE A SMALLER ELEMENT FROM EITHER LIST
while len(L) > 0 and len(R) > 0:
if L[0] < R[0]:
ori_lst[base] = L[0]
L.remove( L[0] )
else:
ori_lst[base] = R[0]
R.remove( R[0] )
base += 1
# UNLOAD THE REMAINER
while len( L ) > 0:
ori_lst[base] = L[0]
L.remove( L[0] )
base += 1
while len( R ) > 0:
ori_lst[base] = R[0]
R.remove( R[0] )
base += 1
# ORIGINAL LIST SHOULD BE SORTED FROM INDEX LEFT TO INDEX RIGHT
def merge_sort( L, left, right ):
if left+1 >= right: # ESCAPE CONDITION
return
mid = left + ( right - left ) // 2
merge_sort( L, left, mid ) # LEFT
merge_sort( L, mid, right ) # RIGHT
merge( L, left, mid, right ) # MERGE
print( "UNSORTED -> ", lst )
merge_sort( lst, 0, n )
print( "SORTED -> ", lst )
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。