当前位置: 首页 > news >正文

leetcode 排序算法汇总

快速排序

def quicksort(arr):
    if len(arr) <= 1:
        return arr
    else:
        pivot = arr[len(arr) // 2]  # 选择中间值作为基准
        left = [x for x in arr if x < pivot]  # 小于基准的放左边
        middle = [x for x in arr if x == pivot]  # 等于基准的放中间
        right = [x for x in arr if x > pivot]  # 大于基准的放右边
        return quicksort(left) + middle + quicksort(right)  # 递归排序

# 测试快速排序算法
arr = [3, 6, 8, 10, 1, 2, 1]
print("原始数组:", arr)
sorted_arr = quicksort(arr)
print("排序后数组:", sorted_arr)
 

冒泡排序

def bubble_sort(arr):
    n = len(arr)
    for i in range(n-1):
        # 标志位用于优化,如果在一轮比较中没有元素交换,说明数组已经有序,可以直接结束排序
        swapped = False
        for j in range(0, n-i-1):
            if arr[j] > arr[j+1]:
                # 交换
                arr[j], arr[j+1] = arr[j+1], arr[j]
                swapped = True
        # 如果没有发生交换,说明数组已经有序,退出循环
        if not swapped:
            break
    return arr

# 示例
arr = [64, 34, 25, 12, 22, 11, 90]
sorted_arr = bubble_sort(arr)
print("Sorted array is:", sorted_arr)

直接插入排序

def insertion_sort(arr):
    # 遍历从1到len(arr)的所有元素
    for i in range(1, len(arr)):
        key = arr[i]  # 当前要插入的元素
        j = i - 1
        # 将当前元素与已排序部分的元素进行比较,找到合适的插入位置
        while j >= 0 and key < arr[j]:
            arr[j + 1] = arr[j]  # 将已排序部分的元素向后移动
            j -= 1
        # 插入当前元素
        arr[j + 1] = key
    return arr

# 示例
if __name__ == "__main__":
    arr = [12, 11, 13, 5, 6]
    print("原始数组:", arr)
    sorted_arr = insertion_sort(arr)
    print("排序后数组:", sorted_arr)
 

二分查找法

def binary_search(arr, target):
    """
    二分查找法
    :param arr: 有序数组
    :param target: 查找目标
    :return: 目标在数组中的索引,如果不存在返回-1
    """
    low = 0
    high = len(arr) - 1

    while low <= high:
        mid = (low + high) // 2
        guess = arr[mid]
        
        if guess == target:
            return mid
        if guess > target:
            high = mid - 1
        else:
            low = mid + 1
    
    return -1

# 示例
if __name__ == "__main__":
    my_list = [1, 3, 5, 7, 9]  # 示例数组
    print(binary_search(my_list, 3))  # 输出:1,因为3在数组中的索引位置是1
    print(binary_search(my_list, -1)) # 输出:-1,因为-1不在数组中
 

http://www.lryc.cn/news/490820.html

相关文章:

  • 【C】错误的变量定义导致sprintf()‌输出错误
  • python基础导包
  • 【含开题报告+文档+PPT+源码】基于SSM的电影数据挖掘与分析可视化系统设计与实现
  • strlwr(arr);的模拟实现(c基础)
  • LCR 002. 二进制求和
  • MySQL-C3P0连数据库报错问题
  • 云计算期中作业:Spark机器学习问题解决
  • 计算机网络socket编程(6)_TCP实网络编程现 Command_server
  • RabbitMQ 集群
  • 从零开始:使用 Spring Boot 开发图书管理系统
  • 速盾:海外服务器使用CDN加速有什么优势?
  • (二)手势识别——动作模型训练【代码+数据集+python环境(免安装)+GUI系统】
  • window系统下使用open-webui+ollama部署大模型
  • 一加ACE 3 Pro手机无法连接电脑传输文件问题
  • 因果机器学习EconML | 客户细分案例——基于机器学习的异质性处理效果估计
  • 找到最大“葫芦”组合
  • shell(9)完结
  • 【计算机网络】多路转接之select
  • 数据库-基础理论
  • Linux——1_系统的延迟任务及定时任务
  • C++ 矩阵旋转
  • Docker学习笔记整理
  • 计算机组成原理期末试题三(含答案)
  • django+boostrap实现注册
  • C++初阶——类和对象(下)
  • 趋势洞察|AI 能否带动裸金属 K8s 强势崛起?
  • idea初始化设置
  • LINUX系统编程之——环境变量
  • 健康老龄化:适合老年人的播客
  • 家庭智慧工程师:如何通过科技提升家居生活质量