n=0;
m=m*10;
k;
}
}
使用Python实现一、冒泡排序
【合并排序实验报告总结 合并排序c语言算法代码】冒泡排序算法的运作如下:
● 比较相邻的元素 。如果第一个比第二个大,就交换他们两个 。
● 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对 。这步做完后,最后的元素会是最大的数 。
● 针对所有的元素重复以上的步骤,除了最后一个 。
● 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较 。
以上节选自维基百科
代码实现:
def bubble_sort(numberlist):
length = len(numberlist)
for i in range(length):
for j in range(1, length - i):
if numberlist[j - 1] > numberlist[j]:
numberlist[j], numberlist[j - 1] = numberlist[j - 1], numberlist[j]
return numberlist
二、选择排序
选择排序(Selection sort)是一种简单直观的排序算法 。它的工作原理如下 。首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾 。以此类推,直到所有元素均排序完毕 。
以上节选自维基百科
代码实现:
def findSmallest(arr): # 用于查找出数组中最小的元素,返回最小元素的索引 。
smallest = arr[0]
smallest_index = 0
for i in range(1, len(arr)):
if smallest > arr[i]:
smallest = arr[i]
smallest_index = i
return smallest_index
def selectSort(arr):
newArr =
while arr:
smallest = findSmallest(arr)
newArr.append(arr.pop(smallest))
return newArr
三、插入排序
步骤如下:
● 从第一个元素开始,该元素可以认为已经被排序
● 取出下一个元素,在已经排序的元素序列中从后向前扫描
● 如果该元素(已排序)大于新元素,将该元素移到下一位置
● 重复步骤3,直到找到已排序的元素小于或者等于新元素的位置
● 将新元素插入到该位置后
重复步骤2~5
以上节选自维基百科
代码实现:
def insert_sort(data):
for k in range(1, len(data)):
cur = data[k]
j = k
while j > 0 and data[j - 1] > cur:
data[j] = data[j - 1]
j -= 1
data[j] = cur
return data
四、希尔排序
希尔排序通过将比较的全部元素分为几个区域来提升插入排序的性能 。这样可以让一个元素可以一次性地朝最终位置前进一大步 。然后算法再取越来越小的步长进行排序,算法的最后一步就是普通的插入排序,但是到了这步,需排序的数据几乎是已排好的了(此时插入排序较快) 。
以上节选自维基百科
代码实现:
def shell_sort(numberlist):
length = len(numberlist)
gap = length // 2
while gap > 0:
for i in range(gap, length):
temp = numberlist[i]
j = i
while j >= gap and numberlist[j - gap] > temp:
numberlist[j] = numberlist[j - gap]
j -= gap
numberlist[j] = temp
gap = gap // 2
return numberlist
五、归并排序
原理如下(假设序列共有{displaystyle n}个元素):
● 将序列每相邻两个数字进行归并操作,形成{displaystyle ceil(n/2)}个序列,排序后每个序列包含两/一个元素
● 若此时序列数不是1个则将上述序列再次归并,形成{displaystyle ceil(n/4)}个序列,每个序列包含四/三个元素
推荐阅读
- excel合并单元格快捷键是什么
- 我来教你Excel把多个单元格内容合并到一个单元格的操作教程 我来教你跳舞
- 小编教你闪电PDF转换成WORD转换器合并或分割PDF文件的详细操作教程
- 小编教你Excel快速合并两列数据/文本的操作教程 小编教你怎么选:羽毛球拍3U和4U的区别
- 教你excel表格里直接相加来求和的操作方法 Excel表合并
- 笔记本电脑分盘教程 电脑分盘怎么合并
- 小编分享迅捷CAD编辑器把CAD里多个图形合并成块的相关流程 迅捷影视分享码
- 西樵实验小学升学率 佛山市公办小学排名?
- 教你Excel 2019自动排序编号的详细步骤教程
- 金山pdf阅读器如何合并pdf文件,几秒达成