Gnome排序(地精排序),起初由Hamid Sarbazi-Azad 于2000年提出,并被称为stupid排序,后来被Dick Grune描述并命名为“地精排序”,作为一个排序算法,和插入排序类似,除了移动一个元素到最终的位置,是通过交换一系列的元素实现,就像冒泡排序一样。概念上十分简单,不需要嵌套循环。时间复杂度为O(n2),但是如果初始数列基本有序,时间复杂度将降为O(n)。实际上Gnome算法可以和插入排序算法一样快。平均运行时间为O(n2).

Gnome排序算法总是查找最开始逆序的一对相邻数,并交换位置,基于交换两元素后将引入一个新的相邻逆序对,并没有假定当前位置之后的元素已经有序.

本文地址:http://www.cnblogs.com/archimedes/p/gnome-sort-algorithm.html,转载请注明源地址。

下面gnome排序算法的伪代码,使用0起始索引数组:

procedure gnomeSort(a[])
    pos :=
    while pos < length(a)
        ])
            pos := pos +
        else
            swap a[pos] and a[pos-]
            )
                pos := pos -
            end if
        end if
    end while
end procedure

实例

给定一个无序数组, a = [5, 3, 2, 4], gnome排序将在while循环中执行如下的步骤.  "current position"采用加粗黑体:

当前数组 操作
[5, 3, 2, 4] a[pos] < a[pos-1], 交换:
[3, 5, 2, 4] a[pos] >= a[pos-1],  pos自增:
[3, 5, 2, 4] a[pos] < a[pos-1], 交换并且pos > 1, pos自减:
[3, 2, 5, 4] a[pos] < a[pos-1], 交换并且pos <= 1, pos自增:
[2, 3, 5, 4] a[pos] >= a[pos-1],  pos自增:
[2, 3, 5, 4] a[pos] < a[pos-1], 交换并且pos > 1, pos自减:
[2, 3, 4, 5] a[pos] >= a[pos-1], pos自增:
[2, 3, 4, 5] a[pos] >= a[pos-1], pos自增:
[2, 3, 4, 5] pos == length(a), 完成.

C代码如下:

// Completed on 2014.10.9 10:01
// Language: C99
//
// 版权所有(C)codingwu   (mail: oskernel@126.com)
// 博客地址:http://www.cnblogs.com/archimedes/

#include<stdio.h>
#include<stdbool.h>
void swap(int *a, int *b)   //交换两元素的值
{
    int t;
    t = *a;
    *a = *b;
    *b = t;
}

void printArray(int a[], int count)   //打印数组元素
{
    int i;
    ; i < count; i++)
        printf("%d ",a[i]);
    printf("\n");
}

void gnome_sort(int *a, int len)   //gnome排序算法
{
    ;
    while(pos < len) {
        ]) {
            pos++;
        } else {
            swap(&a[pos], &a[pos - ]);
            ) pos--;
        }
    }
}

int main(void)
{
    , , , , , , , , };
    int n = sizeof(a) / sizeof(*a);
    printArray(a, n);
    gnome_sort(a, n);
    printArray(a, n);
    ;
}

优化:

gnome算法还可以通过引入一个变量,用于存储每次返回到数组前面的位置来进行优化。采用这样的优化,gnome排序将成为一个变种插入排序,下面优化后gnome排序算法的伪代码,使用0起始索引数组:

procedure optimizedGnomeSort(a[])
    pos :=
    last :=
    while pos < length(a)
        ])
            )
                pos := last
                last :=
            end if
            pos := pos +
        else
            swap a[pos] and a[pos-]
            )
                )
                    last := pos
                end if
                pos := pos -
            else
                pos := pos +
            end if
        end if
    end while
end procedure

C代码如下:

// Completed on 2014.10.9 10:31
// Language: C99
//
// 版权所有(C)codingwu   (mail: oskernel@126.com)
// 博客地址:http://www.cnblogs.com/archimedes/

#include<stdio.h>
#include<stdbool.h>
void swap(int *a, int *b)   //交换两元素的值
{
    int t;
    t = *a;
    *a = *b;
    *b = t;
}

void printArray(int a[], int count)   //打印数组元素
{
    int i;
    ; i < count; i++)
        printf("%d ",a[i]);
    printf("\n");
}
void optimizedGnome_Sort(int *a, int len)   //优化后的gnome排序
{
    int last, pos;
    last = ; pos = ;
    while(pos < len) {
        ]) {
            ) {
                pos = last;
                last = ;
            }
            pos++;
        } else {
            swap(&a[pos], &a[pos - ]);
            ) {
                )
                    last = pos;
                pos--;
            } else {
                pos++;
            }
        }
    }
}
int main(void)
{
    , , , , , , , , };
    int n = sizeof(a) / sizeof(*a);
    printArray(a, n);
    optimizedGnome_Sort(a, n);
    printArray(a, n);
    ;
}

获取更多C语言与算法相关知识,关注公众号:“csuanfa”

Gnome排序算法的更多相关文章

  1. Gnome排序

    Gnome排序(地精排序),起初由Hamid Sarbazi-Azad 于2000年提出,并被称为stupid排序,后来被Dick Grune描述并命名为“地精排序”,作为一个排序算法,和插入排序类似 ...

  2. 地精排序(Gnome Sort) 算法

    gnome应该是最简单排序的排序算法吧!Gnome Sort,这是该算法的作者命名的,O(n*n)时间复杂度,O(1)空间复杂度,属于稳定的排序算法.算法的思想是每趟循环找到第一个逆序的元素,把它和在 ...

  3. 【Unity3D自学记录】可视化对照十多种排序算法(C#版)

    在这篇文章中.我会向大家展示一些排序算法的可视化过程.我还写了一个工具.大家可对照查看某两种排序算法. 下载源代码 – 75.7 KB 下载演示样例 – 27.1 KB 引言 首先,我觉得是最重要的是 ...

  4. JavaScript实现常用的排序算法

    ▓▓▓▓▓▓ 大致介绍 由于最近要考试复习,所以学习js的时间少了 -_-||,考试完还会继续的努力学习,这次用原生的JavaScript实现以前学习的常用的排序算法,有冒泡排序.快速排序.直接插入排 ...

  5. 排序算法----基数排序(RadixSort(L))单链表智能版本

    转载http://blog.csdn.net/Shayabean_/article/details/44885917博客 先说说基数排序的思想: 基数排序是非比较型的排序算法,其原理是将整数按位数切割 ...

  6. 常见排序算法(附java代码)

    常见排序算法与java实现 一.选择排序(SelectSort) 基本原理:对于给定的一组记录,经过第一轮比较后得到最小的记录,然后将该记录与第一个记录的位置进行交换:接着对不包括第一个记录以外的其他 ...

  7. 几大排序算法的Java实现

    很多的面试题都问到了排序算法,中间的算法和思想比较重要,这边我选择了5种常用排序算法并用Java进行了实现.自己写一个模板已防以后面试用到.大家可以看过算法之后,自己去实现一下. 1.冒泡排序:大数向 ...

  8. 排序算法----基数排序(RadixSort(L,max))单链表版本

    转载http://blog.csdn.net/Shayabean_/article/details/44885917博客 先说说基数排序的思想: 基数排序是非比较型的排序算法,其原理是将整数按位数切割 ...

  9. 排序算法汇总(C/C++实现)

    前言:     本人自接触算法近2年以来,在不断学习中越多地发觉各种算法中的美妙.之所以在这方面过多的投入,主要还是基于自身对高级程序设计的热爱,对数学的沉迷.回想一下,先后也曾参加过ACM大大小小的 ...

随机推荐

  1. 关于chrome控制台那些事

    作为一名前端,除了编写完美代码之外(个人还不具备),当然也要会调试啦,对于firebug比较而言,我还是更喜欢chrome控制台比较多(可能使用较多,更顺手的原因吧).所以来总结下,关于chrome控 ...

  2. 最好用的JQuery插件集合以及组合拳

    [Tab页签] Jquery-tab [Table] mmGrid

  3. MVC学习笔记---ModelBinder

    http://www.cnblogs.com/terrysun/archive/2010/04/05/1704666.html http://www.cnblogs.com/aehyok/archiv ...

  4. table_横向合并_纵向合并

    colspan是横向合并; rowspan是纵向合并; <caption></caption>表格标题(自动居中)

  5. Stage3D学习笔记(四):正交矩阵

    我们上一章节显示图片的时候,会发现我们制定的顶点在Stage3D中其实是存在一个区间的: x轴(从左到右):[-1.0-1.0] y轴(从下到上):[-1.0-1.0] z轴(从近到远):[0-1.0 ...

  6. Android:MD5加密

    /** * @author gongchaobin * * MD5加密 * * @version 2013-8-22 */ public class MD5Util { // 用来将字节转换成 16 ...

  7. SRM 583 Div Level Two:IDNumberVerification

    题目来源:http://community.topcoder.com/stat?c=problem_statement&pm=12610 这道题比较有意思,估计是中国人出的吧,以前都不知道身份 ...

  8. windows server 2003断开远程之后自动注销用户

    windows server 2003断开远程之后自动注销用户 2011-07-30 09:42:52     我来说两句      收藏    我要投稿 最近一台服务器老是断开远程之后过没多久就自动 ...

  9. Saltstack 操作目标,正则匹配,及组管理

    如果我们要维护好一个庞大的配置管理系统那么首选得维护好我们的管理对象,在saltstack系统中我们的管理对象叫做Target, 在master上我们可以采用不同Target去管理不同的Minion. ...

  10. Mac下eclipse导入其他工程中文注释出现乱码解决方案

    因为用的是mac版的eclipse,导入其他工程注释出现乱码的情况,找了网上的很多方法,大部分都是说的workspace,在这里修改,但是我修改之后还是乱码,最后发现这样一个方法,才得以解决. 点击 ...