没什么可以多说的,直接看代码吧:
#include <stdio.h>
void display(int array[], int size)
{
int i;
for (i = 0; i < size; ++i)
{
printf("%d ", array[i]);
}
printf("n");
}
void insert_sort(int array[], int size)
{
if (size > 1)
{
insert_sort(array, size - 1);
int temp = array[size - 1];
int i;
for (i = size - 2; i >= 0; --i)
{
if (temp < array[i])
{
array[i + 1] = array[i];
}
else
{
break;
}
}
array[i + 1] = temp;
}
}
int main()
{
int array[] = {4,1,5,2,8};
insert_sort(array, sizeof(array) / sizeof(int));
display(array, sizeof(array) / sizeof(int));
return 0;
}
BTW:我发现我写递归算法的能力不是很强,总是把握不住重点,还得多锻炼才行.
版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明!