??//递归
void insertionSortRecursive(int arr[], int n) {
????if (n <= 1) return;
????insertionSortRecursive(arr, n-1);
????int last = arr[n-1];
????int j = n-2;
????while (j >= 0 && arr[j] > last) {
????????swap(&arr[j], &arr[j+1]);
????????j--;
????}
}
????????????
//非递归
void insertionSort(int arr[], int n) {
????int i, key, j;
????for (i = 1; i < n; i++) {
????????key = arr[i];
????????j = i - 1;
????????while (j >= 0 && arr[j] > key) {
????????????arr[j + 1] = arr[j];
????????????j = j - 1;
????????}
????????arr[j + 1] = key;
????}
} ??????????????????
这两种排序方法的时间复杂度都是O(n^2),随着输入元素个数的增加,运行时间也会线性增加。这是因为在最坏的情况下,对于每个元素,都需要与其他所有元素进行比较和交换。
对于递归实现,假设输入的元素个数为n,那么递归的深度将达到n,因为每次递归调用都会减少一个元素。由于每次递归调用都需要进行参数传递、栈空间分配、返回值处理等操作,因此递归的时间复杂度为O(n^2)。随着输入元素个数的增加,运行时间将呈二次方增长。
对于迭代实现,只需要一个循环就可以完成所有元素的排序。因此,迭代的时间复杂度为O(n^2),与递归实现相同。但是,由于迭代没有进行递归调用,因此不会出现递归调用带来的额外开销。
尽管迭代和递归的实现时间复杂度相同,但迭代实现的效率通常比递归实现更高。