选择排序是一种简单的排序算法,其基本思想是在未排序的序列中找到最小(或最大)的元素,存放到已排序序列的起始位置,然后再从剩余未排序元素中继续寻找最小(或最大)的元素,然后放到已排序序列的末尾,以此类推,直到所有元素均排序完毕。
```python
def selectionSort(arr):
for i in range(len(arr)):
min_idx = i
for j in range(i + 1, len(arr)):
if arr[min_idx] > arr[j]:
min_idx = j
arr[i], arr[min_idx] = arr[min_idx], arr[i]
return arr
示例数组
arr = [64, 34, 25, 12, 22, 11, 90]
print("原始数组:", arr)
sorted_arr = selectionSort(arr)
print("排序后的数组:", sorted_arr)
运行上述代码,你将得到以下输出:
```
原始数组: [64, 34, 25, 12, 22, 11, 90]
排序后的数组: [11, 12, 22, 25, 34, 64, 90]
这段代码定义了一个名为`selectionSort`的函数,它接受一个数组作为参数,并返回排序后的数组。在函数内部,我们使用两个嵌套的循环来实现选择排序算法。外层循环遍历数组的每个位置,内层循环则从当前位置开始寻找最小值的索引。找到最小值后,我们将其与当前位置的元素交换位置。
请注意,上述代码示例使用了Python 3的语法。如果你使用的是Python 2,需要注意一些语法上的差异,例如`print`语句需要用括号包围其参数。