sort函数他不香嘛?为什么还要学各种各样的排序算法!

本文探讨了为什么要学习各种排序算法,而非仅仅依赖如`sort()`这样的函数。文章通过介绍冒泡排序、选择排序、插入排序、希尔排序、归并排序和快速排序等经典算法,阐述了它们的原理和效率。同时提到了Python中`sort()`函数实际上采用了归并排序和插入排序的结合。文章强调理解排序算法背后的逻辑在实际应用中选择合适算法的重要性。
摘要由CSDN通过智能技术生成

前言

说起排序啊,我心里想到的第一个例子就是给定三个数a,b,c按照从小到大的顺序排序输出,这应该算是我们接触编程遇到的最简单的排序问题了叭。不知道大家当时是怎么解决这个问题的?别告诉我你直接sort()哈,其实我当初遇到这个问题的时候是想了一会儿的,包括当时遇到比较三个数大小的问题时,在我们眼里比较三个数的大小或者排序应该是一眼睛就看穿的问题了,但是放进程序语言里可能没有你想象的那么简单。
用C语言写的话,我们之前像这样一定试过,中间的三个if语句写的真是脑壳大。

# include<stdio.h>
int main(){
   
    int a,b,c,temp;
    //读入三个数
    scanf("%d %d %d",&a,&b,&c);
    //三个if 后续有列表解析过程
    if(a>b) temp=a,a=b,b=temp;
    if(b>c) temp=b,b=c,c=temp;
    if(a>b) temp=a,a=b,b=temp;
    //打印排序后的三个数
    printf("%d %d %d",a,b,c);
    return 0;

或许三个数我们还能像这样的完成,要是30个300个数呢?if语句肯定是不行的,这时候就到了我们排序算法发挥他真正实力的时候了!

排序算法

冒泡排序

相信大多数的同学包括我自己接触到的第一个排序算法应该就是冒泡排序。

冒泡排序(英语:Bubble Sort)是一种简单的排序算法。它重复地遍历要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。

在这里插入图片描述
上面是冒泡排序的一个GIF演示图:从第一个元素开始,相邻的两个元素比较大小,然后小的元素放在左边,大的元素就往右边排,这样一趟的话就能找出序列里最大的元素,然后再走n-1趟,倒数第二大的,倒数第三大的…就依次被找出来,直到这个序列有序为止。概括来说:
冒泡排序算法的运作如下:

  • 比较相邻的元素。如果第一个比第二个大(升序),就交换他们两个。
  • 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。这步做完后,最后的元素会是最大的数。
  • 针对所有的元素重复以上的步骤,除了最后一个。
  • 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。
def buble_sort(alist):
    """冒泡排序"""
    n = len(alist)
    for j in range(n-1):
        # 要走多少趟
        count = 0
        for i in range(0, n-1-j):
            # 从头走到尾要走多少次
            if alist[i] > alist[i+1]:
                alist[i], alist[i+1] = alist[i+1], alist[i
  • 10
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 10
    评论
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值