插入排序

343 阅读1分钟

思想

将第一待排序序列第一个元素看做一个有序序列,把第二个元素到最后一个元素当成是未排序序列。 从头到尾一次扫描为排序序列,将扫描到的每个元素插入有序序列的适当位置.(如果待插入的元素与有序序列中的某个元素相等,则将待插入元素插入到相等元素的后面。)

在这里插入图片描述
平均时间复杂度:O(n2)

代码实现

for (int i = 1; i < arr.count; i++) {
    int temp = [arr[i] intValue];
    for (int j = i - 1; j >=0 && temp < [arr[j] intValue]; j--) {
            [arr exchangeObjectAtIndex:j withObjectAtIndex:j+1];
      }
    }
    ```