基础排序算法 and extended

简介

基础的数据结构一般就包括,链表,队列,二叉树图,基础的数据结构对象,再就是比较基础的算法,查找排序,刚开始学算法宇数据结构的小伙伴都会接触到这几种类型,在大学的时候,因为当时是用的C++进行的编程,对几种简单的排序算法比较熟悉,简单的说分为4种,选择排序,冒泡排序,归并排序,希尔排序,这四种可以说是比较常规的四种排序算法,其中冒泡排序跟归并排序算法是稳定的,算法的时间复杂度分别是O(n^2),O(n^2),O(nlog(n)),O(n^2),跟冒泡排序算法相似的,还有个就是快速排序,跟冒泡排序类似,都属属于交换元素排序。下面废话不说,直接贴python实现的代码,个人最近在转python,所以什么还是都是用python撸一把吧。

选择排序

def select_sort(origin_items, comp=lambda x, y: x < y):#不得不说lambda函数是真的好用啊,跟R里面的apply函数族有一拼了
    """简单选择排序"""
    items = origin_items[:]
    for i in range(len(items) - 1):
        min_index = i
        for j in range(i + 1, len(items)):
            if comp(items[j], items[min_index]):#调用定义的lambda函数
                min_index = j
        items[i], items[min_index] = items[min_index], items[i]
    return items
#简单的总结一下,其实选择排序,不断将小的元素向前移动,大的元素向后移,慢慢成为一个有序的序列

冒泡排序

def bubble_sort(origin_items, comp=lambda x, y: x > y):
    """高质量冒泡排序(搅拌排序)"""
    items = origin_items[:]
    for i in range(len(items) - 1):
        swapped = False
        for j in range(i, len(items) - 1 - i):
            if comp(items[j], items[j + 1]):
                items[j], items[j + 1] = items[j + 1], items[j]
                swapped = True
        if swapped:
            swapped = False
            for j in range(len(items) - 2 - i, i, -1):
                if comp(items[j - 1], items[j]):
                    items[j], items[j - 1] = items[j - 1], items[j]
                    swapped = True
        if not swapped:
            break
    return items
####冒泡排序算法跟选择排序很类似,正常的是一次只确定一个最终的位置,一般是确定最大的元素的在排序种的位置,这个是修改之后的冒泡排序算法,主要是多了一步将最小元素排序的操作,也就是一次循环到结尾,再回来的时候将最小的排完,然后以此类推,排序的范围越来越小,提高了排序的效率,也叫做鸡尾酒排序,下面是示意图。
搅拌排序示意图

希尔排序算法

希尔排序是小规模数据排序的最优选择,算法的核心思想就是对插入排序的封装,逐渐减小增量形成新的数组进行插入排序。希尔排序跟前面的白话的排序算法不是很相似,他主要是将数据按步长进行分组,然后对每组中的数,按简单插入排序,然后排序结束之后再将数进行组合,再组合结束后形成新的顺序,然后再将数按新的步长进行排序,随着增量的减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。

对于步长的选择如下
在此我们选择增量gap=length/2,缩小增量继续以gap = gap/2的方式,这种增量选择我们可以用一个序列来表示,{n/2,(n/2)/2...1},称为增量序列。希尔排序的增量序列的选择与证明是个数学难题,我们选择的这个增量序列是比较常用的,也是希尔建议的增量,称为希尔增量,但其实这个增量序列不是最优的。此处我们做示例使用希尔增量。举个简单的例子如下


[例子来源https://www.cnblogs.com/chengxiao/p/6104371.html]

对直接插入排序还不懂的小伙伴需要复习下了,这个是很简单的,说白了就是将无序的队列中的元素插入到有序的队列中
下面是实现的代码

def shell_sort(A):
    N = len(A)
    increment = N//2

    while increment > 0:
        i = increment

        while i < N:
            j = i - increment
            tmp = A[i]

            while j >= 0 and A[j] > tmp:
                A[j + increment] = A[j]
                j -= increment

            A[j + increment] = tmp
            i += 1

        increment //= 2

    return None

归并排序

归并排序算法其实是一种比较经典的分治法排序的算法,将一个大的序列不断分成小的了序列,然后将小的序列进行排序,排完序之后再将这些小的序列进行合并,其实主要是分为两个简单的步骤,第一个是分,第二个是合,个人觉得再合部分可能有点歧义,下面补充一个简单的例子来进行展示。


[例子来源https://www.cnblogs.com/chengxiao/p/6194356.html]

下面直接上代码

def merge_sort(items, comp=lambda x, y: x <= y):
    """归并排序(分治法)"""
    if len(items) < 2:
        return items[:]
    mid = len(items) // 2
    left = merge_sort(items[:mid], comp)
    right = merge_sort(items[mid:], comp)
    return merge(left, right, comp)

def merge(items1, items2, comp):
    """合并(将两个有序的列表合并成一个有序的列表)"""
    items = []
    index, index2 = 0, 0
    while index1 < len(items1) and index2 < len(items2):
        if comp(items1[index1], items2[index2]):
            items.append(items1[index1])
            index1 += 1
        else:
            items.append(items2[index2])
            index2 += 1
    items += items1[index1:]
    items += items2[index2:]
    return items

拓展内容

现在是大数据的时代,那么如何对海量的大数据进行排序呢?其实我觉的 Hadoop就是来解决这种问题,他的Mapreduce策列,可以很好的实现大数据的分布与计算,但这里不进行Hadoop的介绍,这里主要是介绍一些传统的方法。
1.首先比较传统的思想肯定是分割,也就是分治法,大的数据集不断分成小的数据,然后将小的数据进行排序,最后形成有序的数据。特别注意,对数据的分割要是有序的。再就是如果是进一步提高性能的话,可以再I/O的过程进行优化,减少I/O的过程,将多个段进行合并之后在进行I/O操作,还有就是:
可以使用并发的操作:如多磁盘(并发I/O提高)、多线程、使用异步I/O、使用多台主机集群计算等。(其实这些再Hadoop里面可以完全都顾及了,Spark实现map,Hadoop实现对资源的整合与利用)
2.字典树方法,其数据结构如下

String name; // 结点的字符名称
    int fre; // 单词的词频
    boolean end; // 是否是单词结尾
    boolean root; // 是否是根结点
    Node[] children; // 子节点信息
    boolean visited; // 是否已经遍历过了
    int minLength; // 通过该节点的最小的数字长度
    int prefixCount = 0; // 有多少单词通过这个节点,即节点字符出现的次数
    Node parent; // 当前节点的父节点

具体的字典树的操作不在这里详细的赘述。
下次更新下Hadoop里面的Mapreduce的原理过程。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,736评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,167评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,442评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,902评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,302评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,573评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,847评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,562评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,260评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,531评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,021评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,367评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,016评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,068评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,827评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,610评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,514评论 2 269

推荐阅读更多精彩内容

  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 5,101评论 0 52
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    printf200阅读 732评论 0 0
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    闲云清烟阅读 741评论 0 6
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    zwb_jianshu阅读 1,038评论 0 0
  • 本文转自公众号 「程序员私房菜 」 一直有写一篇关于排序算法文章的打算,直到我看到了这一篇,我放弃了自己写的打算,...
    KEEPINUP阅读 2,402评论 4 15