当前位置:主页   - 电脑 - 程序设计 - C/C++
(算法导论习题解exercise2.3-4)递归版插入排序
来源:网络   作者:   更新时间:2010-03-03
收藏此页】    【字号    】    【打印】    【关闭

  没什么可以多说的,直接看代码吧:

#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、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明