C語言的插入排序
阿新 • • 發佈:2019-01-07
#include<stdio.h>
#include<stdlib.h>
#define N 8
void insert_sort(int a[],int n);
//插入排序實現,這裡按從小到大排序
void insert_sort(int a[],int n)//n為陣列a的元素個數
{
//進行N-1輪插入過程
for(int i=1; i<n; i++)
{
//首先找到元素a[i]需要插入的位置
int j=0;
while( (a[j]<a[i]) && (j<i))
{
j++;
}
//將元素插入到正確的位置
if(i != j) //如果i==j,說明a[i]剛好在正確的位置
{
int temp = a[i];
for(int k = i; k > j; k--)
{
a[k] = a[k-1];
}
a[j] = temp;
}
}
}
int main()
{
int num[N] = {89, 38, 11, 78, 96, 44, 19, 25};
insert_sort(num, N);
for(int i=0; i<N; i++)
printf("%d ", num[i]);
printf("\n");
system("pause");
return 0;
}
#include<stdlib.h>
#define N 8
void insert_sort(int a[],int n);
//插入排序實現,這裡按從小到大排序
void insert_sort(int a[],int n)//n為陣列a的元素個數
{
//進行N-1輪插入過程
for(int i=1; i<n; i++)
{
//首先找到元素a[i]需要插入的位置
int j=0;
while( (a[j]<a[i]) && (j<i))
{
j++;
}
//將元素插入到正確的位置
if(i != j) //如果i==j,說明a[i]剛好在正確的位置
{
int temp = a[i];
for(int k = i; k > j; k--)
{
a[k] = a[k-1];
}
a[j] = temp;
}
}
}
int main()
{
int num[N] = {89, 38, 11, 78, 96, 44, 19, 25};
insert_sort(num, N);
for(int i=0; i<N; i++)
printf("%d ", num[i]);
printf("\n");
system("pause");
return 0;
}