python链表冒泡排序、二叉树顺序递归遍历、顺序表的快排

简介: 一、python实现链表冒泡排序- 冒泡排序的概念:冒泡排序是一种交换排序,它的基本思想是:两两比较相邻记录的关键字,如果反序则交换,直至没有反序的记录为止。

一、python实现链表冒泡排序

- 冒泡排序的概念:冒泡排序是一种交换排序,它的基本思想是:两两比较相邻记录的关键字,如果反序则交换,直至没有反序的记录为止。因为按照该算法,每次比较会将当前未排序的记录序列中最小的关键字移至未排序的记录序列最前(或者将当前未排序的记录序列中最大的关键字移至未排序的记录序列最后),就像冒泡一样,故以此为名。
- 冒泡排序算法的算法描述如下:

-- 比较相邻的元素。如果第一个比第二个大,就交换他们两个。
-- 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。这步做完后,最后的元素会是最大的数。
-- 针对所有的元素重复以上的步骤,除了最后一个。
-- 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

1、基本的冒泡排序实现:

li = [23, 43, 1, 2, 4, 5, 253]
def bubble(li):
    if not len(li):
        return
    count = 0
    for i in range(len(li)):
        for j in range(len(li) - 1):
            count+=1
            if li[i] < li[j]:
                li[i], li[j] = li[j], li[i]

    print(count)
    return li

ret_li = bubble(li)
print(ret_li)

42 //循环的次数
[1, 2, 4, 5, 23, 43, 253] //排序结果

2、基本优化

这种方法利用了双重循环,会造成不必要的比较,所以优化一下,可以考虑从尾部开始,这样可以将以排好序的部分不再检查
def bubble(li):
    if not len(li):
        return
    count = 0
    for i in range(len(li)):
        j = len(li) - 1
        while j > i:
            count +=1
            if li[j] < li[j - 1]:
                li[j], li[j - 1] = li[j - 1], li[j]
            j -= 1
    print(count)
    return li

ret_li = bubble(li)
print(ret_li)

21//循环的次数
[1, 2, 4, 5, 23, 43, 253] //排序结果

3、进一步优化

通过设置flag来判断某次循环是否没有出现位置交换,没有交换就说明排序已完成
def bubble(li):
    if not len(li):
        return
    count = 0
    for i in range(len(li)):
        flag = False
        j = len(li) - 1
        while j > i:
            count += 1
            if li[j] < li[j - 1]:
                li[j], li[j - 1] = li[j - 1], li[j]
                flag = True
            j -= 1
        if not flag:
            print(count)
            return li
    return li

ret_li = bubble(li)
print(ret_li)

20 //循环次数
[1, 2, 4, 5, 23, 43, 253] //排序结果

二、二叉树的顺序遍历

  • 二叉树是有限个元素的集合,该集合或者为空、或者有一个称为根节点(root)的元素及两个互不相交的、分别被称为左子树和右子树的二叉树组成。
    -- 二叉树的每个结点至多只有二棵子树(不存在度大于2的结点),二叉树的子树有左右之分,次序不能颠倒。
    -- 二叉树的第i层至多有2^{i-1}个结点
    -- 深度为k的二叉树至多有2^k-1个结点;
    -- 对任何一棵二叉树T,如果其终端结点数为N0,度为2的结点数为N2,则N0=N2+1

  • 二叉树有三种遍历方式:先序遍历,中序遍历,后续遍历 即:先中后指的是访问根节点的顺序 eg:先序 根左右 中序 左根右 后序 左右根
    遍历总体思路:将树分成最小的子树,然后按照顺序输出

#实现树结构的类,树的节点有三个私有属性  左指针 右指针 自己的值
class Node():

    def __init__(self,data =None,left=None,right = None):
        self._data = data
        self._left = left
        self._right = right


#先序遍历  遍历过程 根左右
def pro_order(tree):
    if tree == None:
        return False
    print(tree._data)
    pro_order(tree._left)
    pro_order(tree._right)

#后序遍历  遍历过程 左右根
def pos_order(tree):
    if tree == None:
        return False
    # print(tree.get_data())
    pos_order(tree._left)
    pos_order(tree._right)
    print(tree._data)

#中序遍历  遍历过程  左根右
def mid_order(tree):
    if tree == None:
        return False
    # print(tree.get_data())
    mid_order(tree._left)
    print(tree._data)
    mid_order(tree._right)


#层次遍历  
def row_order(tree):
    # print(tree._data)
    queue = []
    queue.append(tree)
    while True:
        if queue==[]:
            break
        print(queue[0]._data)
        first_tree = queue[0]
        if first_tree._left != None:
            queue.append(first_tree._left)
        if first_tree._right != None:
            queue.append(first_tree._right)
        queue.remove(first_tree)

if __name__ == '__main__':

    tree = Node('A',Node('B',Node('D'),Node('E')),Node('C',Node('F'),Node('G')))
    pro_order(tree)
    mid_order(tree)
    pos_order(tree)
    row_order(tree)

三、python实现顺序表的快排

1、快排的介绍:

快速排序采用的思想是分治思想,先简单的介绍一下分治的思想。分治算法的基本思想是将一个规模为N的问题分解为K个规模较小的子问题,这些子问题相互独立且与原问题性质相同。求出子问题的解,就可以得到原问题的解。下面这张图会说明分治算法是如何进行的:将cn分成了两个cn/2,转而分成了cn/4,cn/8......我们通过这样一层一层的求解规模小的子问题,将其合并之后就能求出原问题的解。

img_01eac8d203b7478b635d9dfe23ae4b33.jpe
图解.jpg

2、快排的基本思路是:

在待排序的序列中选取一个值作为一个基准值,按照这个基准值得大小将这个序列划分成两个子序列,基准值会在这两个子序列的中间,一边是比基准小的,另一边就是比基准大的。这样快速排序第一次排完,我们选取的这个基准值就会出现在它该出现的位置上。这就是快速排序的单趟算法,也就是完成了一次快速排序。然后再对这两个子序列按照同样的方法进行排序,直到只剩下一个元素或者没有元素的时候就停止,这时候所有的元素都出现在了该出现的位置上。
附图:快排的图解

img_c808a76803512c5caf28e66ccf53bbd3.jpe
快排.jpg

3、快排的特点

快速排序之所比较快,因为相比冒泡排序,每次交换是跳跃式的。每次排序的时候设置一个基准点,将小于等于基准点的数全部放到基准点的左边,将大于等于基准点的数全部放到基准点的右边。这样在每次交换的时候就不会像冒泡排序一样每次只能在相邻的数之间进行交换,交换的距离就大的多了。因此总的比较和交换次数就少了,速度自然就提高了。当然在最坏的情况下,仍可能是相邻的两个数进行了交换。因此快速排序的最差时间复杂度和冒泡排序是一样的都是O(N2),它的平均时间复杂度O(NlogN)。其实快速排序是基于一种叫做“二分”的思想。

4、快排的代码实现
def quick_sort(li):
    if len(li) <= 1:
        return li
    base_value = li[len(li) // 2]
    left_part = [item for item in li if item < base_value]
    right_part = [item for item in li if item > base_value]
    eq_part = [item for item in li if item == base_value]
    return quick_sort(left_part) + eq_part + quick_sort(right_part)

print(quick_sort(li = [23, 43, 1, 2, 4, 5, 253]))

简洁版的快排,两种代码其实是一样的

def quick_sort(li):
    if len(li) <= 1:
        return li
    return quick_sort([item for item in li[1:] if item < li[0]])+ li[0:1] + quick_sort([item for item in li[1:] if item > li[0]])

print(quick_sort(li = [23, 43, 1, 2, 4, 5, 253]))
相关文章
|
2月前
|
搜索推荐 Python
利用Python内置函数实现的冒泡排序算法
在上述代码中,`bubble_sort` 函数接受一个列表 `arr` 作为输入。通过两层循环,外层循环控制排序的轮数,内层循环用于比较相邻的元素并进行交换。如果前一个元素大于后一个元素,就将它们交换位置。
143 67
|
13天前
|
存储 算法 Python
文件管理系统中基于 Python 语言的二叉树查找算法探秘
在数字化时代,文件管理系统至关重要。本文探讨了二叉树查找算法在文件管理中的应用,并通过Python代码展示了其实现过程。二叉树是一种非线性数据结构,每个节点最多有两个子节点。通过文件名的字典序构建和查找二叉树,能高效地管理和检索文件。相较于顺序查找,二叉树查找每次比较可排除一半子树,极大提升了查找效率,尤其适用于海量文件管理。Python代码示例包括定义节点类、插入和查找函数,展示了如何快速定位目标文件。二叉树查找算法为文件管理系统的优化提供了有效途径。
45 5
|
13天前
|
数据库
数据结构中二叉树,哈希表,顺序表,链表的比较补充
二叉搜索树,哈希表,顺序表,链表的特点的比较
数据结构中二叉树,哈希表,顺序表,链表的比较补充
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 32 - III. 从上到下打印二叉树 III
本文介绍了两种Python实现方法,用于按照之字形顺序打印二叉树的层次遍历结果,实现了在奇数层正序、偶数层反序打印节点的功能。
65 6
|
2月前
|
算法 Python
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果;贪心算法在每一步选择局部最优解,追求全局最优;动态规划通过保存子问题的解,避免重复计算,确保全局最优。这三种算法各具特色,适用于不同类型的问题,合理选择能显著提升编程效率。
67 2
|
3月前
|
Java 程序员 C++
【Python】链式、嵌套调用、递归、函数栈帧、参数默认值和关键字参数
【Python】链式、嵌套调用、递归、函数栈帧、参数默认值和关键字参数
38 0
【Python】链式、嵌套调用、递归、函数栈帧、参数默认值和关键字参数
|
5月前
|
搜索推荐 Python
Python基础编程:冒泡排序和选择排序的另一种while循环实现
这篇文章介绍了Python中冒泡排序和选择排序的实现,提供了使用while循环的替代方法,并展示了排序算法的运行结果。
41 2
Python基础编程:冒泡排序和选择排序的另一种while循环实现
|
3月前
|
算法 Python
Python算法编程:冒泡排序、选择排序、快速排序
Python算法编程:冒泡排序、选择排序、快速排序
40 0
|
5月前
|
算法 Python
python函数递归和生成器
python函数递归和生成器
|
5月前
|
算法 数据挖掘 Python