快速排序的python实现

本文详细介绍了快速排序和冒泡排序算法的实现过程,包括两种算法的基本原理、实现代码及性能比较。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#! /usr/bin/env python
# -*- coding:utf-8 -*-


import sys


class sort(object) :
    @classmethod
    def __bubble_sort(cls, data = [], start = 0, end = -1) :
        if end < 0 :
            end += len(data)
        if end > len(data) :
            end = len(data)

        if end <= start :
            return None

        for i in range(start, end) :
            for j in range(i + 1, end + 1) :
                if data[i] > data[j] :
                    data[i], data[j] = data[j], data[i]
        return None

    @classmethod
    def __quick_sort(cls, data = [], start = 0, end = -1) :
        def __mid__(data, a, b, c) :
            if data[a] > data[b] :
                if data[a] < data[c] :
                    return a
                elif data[b] > data[c] :
                    return b
                else :
                    return c
            else :
                if data[b] < data[c] :
                    return b
                elif data[a] > data[c] :
                    return a
                else :
                    return c

        if (end - start + 1) < 3 :
            return cls.__bubble_sort(data, start, end)

        if end < 0 :
            end += len(data)
        if end > len(data) :
            end = len(data)

        if end <= start :
            return None

        pivot = __mid__(data, start, start + (end - start) / 2, end)
        data[pivot], data[end] = data[end], data[pivot]

        pivot = end
        i = start
        j = end - 1
        while True :
            if data[i] > data[pivot] :
                data[i], data[j] = data[j], data[i]
            else :
                i += 1
            if i > j :
                break;
            if data[j] < data[pivot] :
                data[j], data[i] = data[i], data[j]
            else :
                j -= 1
            if i > j :
                break;

        data[i], data[pivot] = data[pivot], data[i]
        pivot = i

        cls.__quick_sort(data, start, pivot - 1)
        cls.__quick_sort(data, pivot + 1, end)

    @classmethod
    def do_sort(cls, data, start = 0, end = -1) :
        cls.__quick_sort(data, start, end)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值