算法:冒泡排序、插入排序、快速排序、堆排序

冒泡排序

#! /usr/bin/env python
# -*- coding: utf-8 -*-
# __author__ = "Q1mi"
# Email: master@liwenzhou.com

"""
冒泡排序
"""

import random
import time

def get_list(arg):
    """
    获得一个有指定个数的1000以内数字的列表
    :param arg: 期望获得的列表内数字的个数
    :return:
    """
    list_tmp = []
    for i in range(arg):
        list_tmp.append(random.randrange(100000))
    return list_tmp

def bubble_sort(arg):
    n = 0
    for i in range(len(arg)-1):
        n += 1
        for j in range(i+1, len(arg)):
            n += 1
            if arg[i] < arg[j]:
                arg[i], arg[j] = arg[j], arg[i]
    print("此次循环:{} 次。".format(n))
    return arg

if __name__ == "__main__":
    l1 = get_list(50000)
    start_time = time.time()
    l2 = bubble_sort(l1)
    end_time = time.time()
    print("此次耗时:{} 秒。".format(end_time-start_time))

bobble sort

选择排序

#! /usr/bin/env python
# -*- coding: utf-8 -*-
# __author__ = "Q1mi"
# Email: master@liwenzhou.com

"""
选择排序
"""

import random
import time

def get_list(arg):
    """
    获得一个有指定个数的1000以内数字的列表
    :param arg: 期望获得的列表内数字的个数
    :return:
    """
    list_tmp = []
    for i in range(arg):
        list_tmp.append(random.randrange(100000))
    return list_tmp

def selection_sort(arg):
    n = 0
    for i in range(len(arg)-1):
        n += 1
        index = i
        for j in range(i+1, len(arg)):
            n += 1
            # 从i之后的元素中找最小的,然后和arg[i]交换
            if arg[index] > arg[j]:
                index = j
        arg[i], arg[index] = arg[index], arg[i]
    print("此次循环:{} 次。".format(n))
    return arg

if __name__ == "__main__":
    l1 = get_list(50000)
    start_time = time.time()
    l2 = selection_sort(l1)
    end_time = time.time()
    print("此次耗时:{} 秒。".format(end_time-start_time))

selection sort

插入排序

#! /usr/bin/env python
# -*- coding: utf-8 -*-
# __author__ = "Q1mi"
# Email: master@liwenzhou.com

"""
插入排序
"""

import random
import time

def get_list(arg):
    """
    获得一个有指定个数的1000以内数字的列表
    :param arg: 期望获得的列表内数字的个数
    :return:
    """
    list_tmp = []
    for i in range(arg):
        list_tmp.append(random.randrange(100000))
    return list_tmp

def insertion_sort(arg):
    n = 0
    for i in range(1, len(arg)):
        n += 1
        # 记下当前的索引
        index = i
        # 记下当前值
        current_value = arg[i]
        # 如果索引大于0,并且它前面已经排序了的列表的最后一个值比当前值大
        while index > 0 and arg[index-1] > current_value:
            # 就把它之前已经排序了的列表的值往后移一位
            arg[index] = arg[index-1]
            # 接着在已经排序的列表往前取值比较
            index -= 1
            n += 1
        # 如果索引=0或者当前的已经排序了的列表中索引为index-1的值比当前值小
        # 那么就把current_value放到index位置
        arg[index] = current_value
    print("此次循环:{} 次。".format(n))
    return arg

if __name__ == "__main__":
    l1 = get_list(50000)
    start_time = time.time()
    l2 = insertion_sort(l1)
    end_time = time.time()
    print("此次耗时:{} 秒。".format(end_time-start_time))

insertion sort

快速排序

#! /usr/bin/env python
# -*- coding: utf-8 -*-
# __author__ = "Q1mi"
# Email: master@liwenzhou.com

"""
快速排序
"""

import random
import time

def get_list(arg):
    """
    获得一个有指定个数的1000以内数字的列表
    :param arg: 期望获得的列表内数字的个数
    :return:
    """
    list_tmp = []
    for i in range(arg):
        list_tmp.append(random.randrange(1000000))
    return list_tmp

def quick_sort(original_list, start, end):
    """

    :param original_list: 待排序的列表
    :param start: 第一个元素的索引
    :param end: 最后一个元素的索引
    :return:
    """
    # 参数输错直接退出
    if start >= end:
        return
    # 取一个key值
    value_key = original_list[start]

    left = start
    right = end

    while left < right:
        # 先从右往左比较
        while left < right and original_list[right] > value_key:
            right -= 1
        # 把最前面的值跟这个比key小的值互换
        # 把最左边的值换成从右往左找到的那个比key小的那个值
        original_list[left], original_list[right] = original_list[right], original_list[left]
        #
        while left < right and original_list[left] <= value_key:
            left += 1
        # 如果从左往右找到了比key大的数
        original_list[left], original_list[right] = original_list[right], original_list[left]
    quick_sort(original_list, start, left-1)
    quick_sort(original_list, right+1, end)

if __name__ == "__main__":
    l1 = get_list(500000)
    start_time = time.time()
    quick_sort(l1, 0, len(l1)-1)
    end_time = time.time()
    print("此次耗时:{} 秒。".format(end_time-start_time))

quick sort

堆排序

#! /usr/bin/env python
# -*- coding: utf-8 -*-
# __author__ = "Q1mi"
# Email: master@liwenzhou.com

"""
堆排序
"""

import random
import time

def get_list(arg):
    """
    获得一个有指定个数的1000以内数字的列表
    :param arg: 期望获得的列表内数字的个数
    :return:
    """
    list_tmp = []
    for i in range(arg):
        list_tmp.append(random.randrange(1000000))
    return list_tmp

def sift_down(lst, start, end):
    """

    :param lst: 待排序的数组
    :param start: 开始排序的节点
    :param end: 末节点
    :return: 调整为最大堆结构
    """
    root = start
    while True:
        child = 2 * root + 1  # 默认设置左子节点为最大子节点
        # 子节点越界就跳出
        if child > end:
            break
        # 如果右子节点没越界,并且右子节点的值比左子节点大
        if child + 1 <= end and lst[child] < lst[child+1]:
            # 设置右子节点为最大子节点
            child += 1
        # 如果根节点的数小于值大的那个子节点
        if lst[root] < lst[child]:
            # 互换位置
            lst[root], lst[child] = lst[child], lst[root]
            # 设置正在调整的节点为root
            root = child
        # 无需调整就退出
        else:
            break

def heap_sort(lst):
    for i in range(len(lst)//2, -1, -1):
        sift_down(lst, i, len(lst)-1)
    for j in range(len(lst)-1, 0, -1):
        lst[0], lst[j] = lst[j], lst[0]
        sift_down(lst, 0, j-1)
    return lst

if __name__ == "__main__":
    list_demo = get_list(500000)
    start_time = time.time()
    heap_sort(list_demo)
    end_time = time.time()
    print("此次耗时:{} 秒。".format(end_time-start_time))

heap sort

Python之路Day17的更多相关文章

  1. Python之路,Day17 - 分分钟做个BBS论坛

    Python之路,Day17 - 分分钟做个BBS论坛   本节内容: 项目:开发一个简单的BBS论坛 需求: 整体参考"抽屉新热榜" + "虎嗅网" 实现不同 ...

  2. Python之路【第一篇】python基础

    一.python开发 1.开发: 1)高级语言:python .Java .PHP. C#  Go ruby  c++  ===>字节码 2)低级语言:c .汇编 2.语言之间的对比: 1)py ...

  3. Python之路

    Python学习之路 第一天   Python之路,Day1 - Python基础1介绍.基本语法.流程控制              第一天作业第二天   Python之路,Day2 - Pytho ...

  4. python之路 目录

    目录 python python_基础总结1 python由来 字符编码 注释 pyc文件 python变量 导入模块 获取用户输入 流程控制if while python 基础2 编码转换 pych ...

  5. Python之路【第十九篇】:爬虫

    Python之路[第十九篇]:爬虫   网络爬虫(又被称为网页蜘蛛,网络机器人,在FOAF社区中间,更经常的称为网页追逐者),是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本.另外一些不常使用 ...

  6. Python之路【第十八篇】:Web框架们

    Python之路[第十八篇]:Web框架们   Python的WEB框架 Bottle Bottle是一个快速.简洁.轻量级的基于WSIG的微型Web框架,此框架只由一个 .py 文件,除了Pytho ...

  7. Python之路【第十七篇】:Django【进阶篇 】

    Python之路[第十七篇]:Django[进阶篇 ]   Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接 ...

  8. Python之路【第十六篇】:Django【基础篇】

    Python之路[第十六篇]:Django[基础篇]   Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了O ...

  9. Python之路【第十五篇】:Web框架

    Python之路[第十五篇]:Web框架   Web框架本质 众所周知,对于所有的Web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端. 1 2 3 4 5 6 ...

随机推荐

  1. Java和Android开发IDE---IntelliJ IDEA使用技巧(转)

    以前一直使用的是Eclipse,听别人介绍说IDEA非常不错,也为了以后转Android studio铺垫下.就开始尝试用idea来开发. 这篇文章主要学习了idea的使用技巧. IDEA 全称 In ...

  2. C++使用OLE高速读写EXCEL的源码

    我的代码参考的地方是这儿,再次感谢原作者 http://blog.csdn.net/gyssoft/archive/2007/04/29/1592104.aspx 我根据自己的需要做了整理,干净了一点 ...

  3. Codeforces Beta Round #97 (Div. 2)

    A题求给出映射的反射,水题 #include <cstdio> int x,ans[105],n; int main(){ scanf("%d",&n); fo ...

  4. javascript的this指向

    JavaScript 是一种脚本语言,支持函数式编程.闭包.基于原型的继承等高级功能.JavaScript一开始看起来感觉会很容易入门,但是随着使用的深入,你会发现JavaScript其实很难掌握,有 ...

  5. gdb篇

    转自:http://www.cnblogs.com/ypchenry/p/3668572.html 1.gdb的原理 熟悉linux的同学面试官会问你用过gdb么?那好用过,知道gdb是怎么工作的么? ...

  6. 刚开始学HTML自己做的,求大神些多多指教。

    !DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> ...

  7. mysql 数据备份

    一.备份数据库并下载到本地[db_backup.php] php代码: <?php // 数据库参数(此处测试,直接给定,项目中使用配置文件) $cfg_dbname = 'blog'; $cf ...

  8. JS中的replace方法

    JavaScript中replace() 方法如果直接用str.replace("-","!") 只会替换第一个匹配的字符. 而str.replace(/\-/ ...

  9. WPF之DataGrid应用(转)

    原文:http://blog.csdn.net/sanjiawan/article/details/6785394 前几天打算尝试下DataGrid的用法,起初以为应该很简单,可后来被各种使用方法和功 ...

  10. ExtJS003单击按钮弹出window

    html部分 <input type="button" id="btn" name="name" value="点击&quo ...