C/C++程序员:基本排序算法之插入排序
2014-04-29 09:41
363 查看
插入排序
10 20 30 40 50
1)算法
A.首元素自然有序;
B.取出下一个元素,对已排序序列,从后向前扫描;
C.大于被取出元素者后移;
D.小于等于被取出元素者,将被取出元素插入其后;
E.重复步骤B,直至处理完所有元素。
2)评价
A.平均时间复杂度:O(N^2)
B.稳定排序。
C.对数据的有序性非常敏感。
D.不做交换而是移动,优于冒泡排序。
#inlcude <stdio.h>
#include <stdlib.h>
/* 插入排序 */
void insert_sort (int data[], size_t size) {
size_t i;
for (i = 1; i < size; ++i) {
int inserted = data[i];
size_t j;
for (j = i; j > 0 && inserted < data[j-1];
--j)
data[j] = data[j-1];
if (j != i)
data[j] = inserted;
}
}
/* 测试用例 */
int main (void) {
srand (time (NULL));
int data[10];
size_t i, size = sizeof(data) / sizeof(data[0]);
for (i = 0; i < size; ++i)
printf ("%2d ", data[i] = rand () % 100);
printf ("\n");
insert_sort (data, size);
for (i = 0; i < size; ++i)
printf ("%2d ", data[i]);
printf ("\n");
return 0;
}
10 20 30 40 50
1)算法
A.首元素自然有序;
B.取出下一个元素,对已排序序列,从后向前扫描;
C.大于被取出元素者后移;
D.小于等于被取出元素者,将被取出元素插入其后;
E.重复步骤B,直至处理完所有元素。
2)评价
A.平均时间复杂度:O(N^2)
B.稳定排序。
C.对数据的有序性非常敏感。
D.不做交换而是移动,优于冒泡排序。
#inlcude <stdio.h>
#include <stdlib.h>
/* 插入排序 */
void insert_sort (int data[], size_t size) {
size_t i;
for (i = 1; i < size; ++i) {
int inserted = data[i];
size_t j;
for (j = i; j > 0 && inserted < data[j-1];
--j)
data[j] = data[j-1];
if (j != i)
data[j] = inserted;
}
}
/* 测试用例 */
int main (void) {
srand (time (NULL));
int data[10];
size_t i, size = sizeof(data) / sizeof(data[0]);
for (i = 0; i < size; ++i)
printf ("%2d ", data[i] = rand () % 100);
printf ("\n");
insert_sort (data, size);
for (i = 0; i < size; ++i)
printf ("%2d ", data[i]);
printf ("\n");
return 0;
}
相关文章推荐
- C/C++程序员:基本排序算法之快速排序
- 算法_基本排序算法之冒泡排序,选择排序,插入排序和希尔排序
- 基本排序算法——插入排序java实现
- 基本排序算法的实现代码(c++)
- 排序算法用C++的基本算法实现十个数排序
- 经典算法(8)- 插入排序(Insertion Sort) 及三个基本排序算法的比较
- 【排序算法】插入排序(C++实现)
- [C++]数据结构:排序算法Part1----冒泡排序、选择排序、插入排序、堆排序
- 用于测试C++/C程序员的基本编程技能、编程质量以及对C++/C的理解程度的一份考卷试题
- 用于测试C++/C程序员的基本编程技能、编程质量以及对C++/C的理解程度的一份考卷试题
- 排序算法之插入排序的C++实现
- 三种基本排序算法-冒泡排序,选择排序,插入排序
- C/C++:各种基本算法实现小结(五)—— 排序算法
- 用于测试C++/C程序员的基本编程技能、编程质量以及对C++/C的理解程度的一份考卷试题
- 用于测试C++/C程序员的基本编程技能、编程质量以及对C++/C的理解程度的一份考卷试题
- c/c++常用算法(11) -- 基本排序算法(插入排序)
- 基本排序算法(冒泡排序 选择排序 插入排序 快速排序 归并排序 基数排序 希尔排序)
- 用于测试C++/C程序员的基本编程技能、编程质量以及对C++/C的理解程度的一份考卷试题
- 面试最基本的三种排序算法 冒泡排序 插入排序 选择排序
- C语言基本排序算法之插入排序与直接选择排序实现方法