直接插入排序算法
很多情况下需要用到一些基础的排序算法,接下来分析直接插入排序算法:
1.待排序数组a分为两个区间,一个是已经安排好排序的子区间b,另外一个时当前数组未排序部分c;
2.将c中一个元素继续跟b中有序列进行比较,找到合适位置插入;
3.数组c不为空时循环操作2;
一、构图分析:
二、 代码实现:
#include<iostream>
#include<iomanip>
using namespace std;
typedef int KeyType;//自定义需要排序数组类型(此处为int)
void directInsertQueue(KeyType R[],int n)
{
int i;
int j;
KeyType temp;//使用一个变量作为每次比较中转变量
for( i = 1; i < n; i++ )//初始数组a从R[0]与R[1]间隔开成b,c两部分
{
temp = R[i];
j = i - 1;
while(j >= 0 && temp < R[j])//c中R[1]及其后每一个元素在确定自己的位置时,需要跟前边b中有序序列依次比较(while循环实现)
{
R[j+1] = R[j];
j--;
}
R[j+1] = temp;//c中每一个元素当找到自己位置后,将此元素插入 b中有序序列
}
cout<<"经过直接插入排序算法所得序列:"<<endl;
for( i = 0; i < n; i++ )
{
cout<<setw(5)<<R[i];//设置输出格式
}
}
int main()
{
int a[4]={333,67,1000,0};
directInsertQueue(a,4);
return 0;
}
三、算法分析:
时间复杂度:o(n^2)
空间复杂度:o(1)