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 | # 选择排序 # 一趟排序记录最小值,放到第一个位置 #再一趟排序记录记录列表无序区最小的数,放到第二个位置 #.... # 关键点:有序区、无序区、无序区最小值 #方法一 def select_Sort1(li): li2 = [] for i in range ( len (li)): min_li = min (li) #此方法不建议,生成两个数组占用内存 li2.append(min_li) #其中append和remove 都是大于O(1) li.remove(min_li) return li2 li = [ 2 , 1 , 3 , 4 , 7 , 9 , 5 , 6 ] print (select_Sort1(li)) """ [1, 2, 3, 4, 5, 6, 7, 9] """ #方法二 复杂度 O(n^2) def select_Sort2(li): for i in range ( len (li) - 1 ): # i代表第几趟 min_loc = i #定义无序区最小数位置 for j in range (i + 1 , len (li)): # 第一个数就不用跟自己比,故i+1 if li[j] < li[min_loc]: min_loc = j li[i],li[min_loc] = li[min_loc],li[i] print (li) li = [ 2 , 1 , 3 , 4 , 7 , 9 , 5 , 6 ] print ( "方法二:原列表:" + str (li)) select_Sort2(li) """ 方法二:原列表:[2, 1, 3, 4, 7, 9, 5, 6] [1, 2, 3, 4, 7, 9, 5, 6] [1, 2, 3, 4, 7, 9, 5, 6] [1, 2, 3, 4, 7, 9, 5, 6] [1, 2, 3, 4, 7, 9, 5, 6] [1, 2, 3, 4, 5, 9, 7, 6] [1, 2, 3, 4, 5, 6, 7, 9] [1, 2, 3, 4, 5, 6, 7, 9] """ |
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步