Leetcode Day14排序算法

动态git可以看 :https://leetcode.cn/problems/sort-an-array/solutions/179370/python-shi-xian-de-shi-da-jing-dian-pai-xu-suan-fa/

选择排序

def selection_sort(nums):n = len(nums)for i in range(n):for j in range(i, n):if nums[i] > nums[j]:nums[i], nums[j] = nums[j], nums[i]return nums

为什么只交换严格小于的呢?在这里插入图片描述

插入排序

class Solution:def sortArray(self, nums: List[int]) -> List[int]:for i in range(1, len(nums)):while i > 0 and nums[i] < nums[i - 1]:nums[i-1], nums[i] = nums[i], nums[i-1]i -= 1return nums

注意使用里面的while loop来实现一直交换的效果

冒泡排序

class Solution:def sortArray(self, nums: List[int]) -> List[int]:for i in range(len(nums)):swapped = Falsefor j in range(1, len(nums) - i):if nums[j] < nums[j - 1]:nums[j], nums[j - 1] = nums[j - 1], nums[j]swapped = Trueif not swapped:breakreturn nums

注意两个点: 1.用最外层的for loop代表最后n个数字已经完成了排序 2. 用swap变量来提前终止循环

merge sort

def merge_sort(nums):if len(nums) <= 1:return numsmid = len(nums) // 2# 分left = merge_sort(nums[:mid])right = merge_sort(nums[mid:])# 合并return merge(left, right)def merge(left, right):res = []i = 0j = 0while i < len(left) and j < len(right):if left[i] <= right[j]:res.append(left[i])i += 1else:res.append(right[j])j += 1res += left[i:]res += right[j:]return res

注意不要忘记了base case哦

快速排序 (注意下partition那一步是怎么写的)

def quick_sort(nums):n = len(nums)def quick(left, right):if left >= right:return numspivot = lefti = leftj = rightwhile i < j:while i < j and nums[j] >= nums[pivot]:j -= 1while i < j and nums[i] <= nums[pivot]:i += 1nums[i], nums[j] = nums[j], nums[i]nums[pivot], nums[j] = nums[j], nums[pivot]quick(left, j - 1)quick(j + 1, right)return numsreturn quick(0, n - 1)

一定要注意是先变化j, 因为我们的pivot是从index 0 选的, 就应该从对面开始

215 数组中第k大的元素

就是quick_select

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/52636.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

甲基化组学全流程生信分析教程

甲基化组学全流程分析和可视化教程 读取数据目录下的idat文件的甲基化全流程一键分析 功能简介 甲基化分析模块可以实现甲基化芯片450K, 870kEPIC数据的自动读取&#xff0c;可以读取idat文件&#xff0c;也可以读取beta甲基化矩阵文件甲基化数据的缺失值插值甲基化数据的质…

我如何使用 Graphviz 来优化我的模型图的布局,,python 人工智能 深度神经网络,

在 Python 中&#xff0c;如果你已经使用 Pyro 的 render_model 函数生成了一个模型的 Graphviz 表示&#xff08;mace_graph&#xff09;&#xff0c;你可以使用 Graphviz 的 Python 绑定来显示或保存这个图。以下是一些步骤和示例代码&#xff0c;展示如何在 Python 中处理和…

python测试框架之Pytest

初识Pytest Pytest1.Pytest的特点&#xff1a;2.Pytest的基本使用规则3.pytest安装1&#xff09;使用编译器安装2&#xff09;使用命令安装 4.pytest规则 Pytest Pytest是python的一个第三方单元测试库&#xff0c;它的目的是让单元测试变得容易&#xff0c;并且也能扩展到支持…

解析云上实时数仓的挑战与实践 | Databend @DTCC 2024 演讲回顾

8 月 22 日 ~ 24 日&#xff0c;由 IT168 联合旗下 ITPUB、ChinaUnix 两大技术社区主办的第 15 届中国数据库技术大会&#xff08;DTCC2024&#xff09;在北京朗丽兹西山花园酒店成功召开。本次大会以“自研创新 数智未来”为主题&#xff0c;通过深度交流与探讨&#xff0c;推…

Vue3组件通讯六种方式

1. Props Props 是 Vue.js 中最基本的组件通信方式之一&#xff0c;用于父组件向子组件传递数据。Props 是一种单向数据流&#xff0c;即父组件通过 props 将数据传递给子组件&#xff0c;子组件接收这些 props 并在内部使用它们&#xff0c;但不能直接修改它们。在 Vue3 中&a…

如何在手机上设置国内代理IP地址:详细指南

在某些情况下&#xff0c;我们可能需要在手机上设置国内代理IP地址&#xff0c;以便访问特定的网络服务或提高网络连接的稳定性。本文将详细介绍如何在Android和iOS设备上设置代理IP地址。 在Android设备上设置代理IP地址 在Android设备上设置代理IP地址非常简单&#xff0c;只…

MYSQL:简述对B树和B+树的认识

MySQL的索引使用B树结构。 1、B树 在说B树之前&#xff0c;先说说B树&#xff0c;B树是一个多路平衡查找树&#xff0c;相较于普通的二叉树&#xff0c;不会发生极度不平衡的状况&#xff0c;同时也是多路的。 B树的特点是&#xff1a;他会将数据也保存在非叶子节点。而这个…

centOS安装R语言4.0及以上

centOS安装R语言4.0及以上 源码编译安装R安装配置必要的依赖库安装配置必要图片库检测配置R问题1&#xff1a;R语言安装依赖&#xff0c;缺啥补啥问题2&#xff1a;依赖 curl7 and curl >7.28 检查配置&#xff0c;如果没问题&#xff0c;进行编译安装安装Rstudio-server参考…

【Kubernetes】k8s集群之HPA

目录 一、HPA 概述 二、部署 metrics-server 三、部署 HPA 四、总结 一、HPA 概述 HPA&#xff08;Horizontal Pod Autoscaling&#xff09;Pod 水平自动伸缩&#xff0c;Kubernetes 有一个 HPA 的资源&#xff0c;HPA 可 以根据 CPU 利用率自动伸缩一个 Replication Con…

C# 实现傅里叶变化(DFT)

1、DFT函数类 using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks;namespace DFT_FFTApp.Utils {public class DFT{/// <summary>/// DFT/// </summary>/// <param name"data"&g…

Systemc example based on VCS

README VCS example path: $VCS_HOME/doc/examples/systemc/ SYSTEMC_HOME: module load systemc(or 自己download systemc, VCS_HOME下应该也有&#xff1a;$VCS_HOME/include/systemc233/tlm_utils) gcc需要是7.3.0版本&#xff0c;module load gcc/7.3.0 注意事项 vcs …

C语言典型例题55

《C程序设计教程&#xff08;第四版&#xff09;——谭浩强》 题目&#xff1a; 例题4.7 兔子的繁殖。这是一个有趣的古典问题&#xff1a;有一对兔子&#xff0c;从出生后的第3个月开始起每个月都生一对兔子。小兔子长到第3个月又生一对兔子。假设所有兔子都不死&#xff0c;…

二叉搜索树进阶之红黑树

前言&#xff1a; 在上文我们已经学习了AVL树的相关知识以及涉及的四种旋转的内容&#xff0c;但是AVL树追求平衡导致旋转操作过多&#xff0c;一些情况下影响性能&#xff0c;由此我们就来了解一下二叉搜索树的另外一个分支&#xff0c;红黑树。 &#xff08;倘若对旋转知识…

2024版Assimp配置教程

最近想看看图形学&#xff0c;选择速通LearnOpenGL&#xff0c;不出意外最耗时间的依然是配置环境。按照教程上的把GLFW等等配置的没有问题&#xff0c;但是在Assimp这里卡住了。原因是教程上说的不详细&#xff0c;而网上查的又和现在的版本相去甚远&#xff0c;导致捣鼓了好一…

从web.xml动态读取sunspringmvc.xml文件

文章目录 1.问题分析1.SunWebApplicationContext.java 中sunspringmvc.xml是写死的2.但是web.xml已经配置了init-param&#xff0c;所以应该是可以读取的 2.具体实现1.SunDispatcherServlet.java 得到ServletConfig传递给Spring容器完成初始化2.SunWebApplicationContext.java …

Python中的“for循环”:探索其无限潜力

引言 for循环是任何Python程序员工具箱中的必备技能之一。无论是在处理数据时需要遍历数组&#xff0c;还是在编写Web应用时循环处理请求&#xff0c;亦或是进行复杂的算法实现&#xff0c;for循环都能派上大用场。通过掌握for循环的不同用法&#xff0c;我们可以更高效地解决…

【C++从小白到大牛】C++的隐式和显示类型转换基础知识讲解

目录 1、C语言中的类型转换 2、C语言和C中可以相互转换的类型总结 C语言&#xff1a; CPP&#xff1a; 3. 为什么C需要四种类型转换 4、C四大强制类型转换 4.1static_cast 4.2 reinterpret_cast 4.3 const_cast 4.4dynamic_cast 注…

基于x86 平台opencv的图像采集和seetaface6的性别识别功能

目录 一、概述二、环境要求2.1 硬件环境2.2 软件环境三、开发流程3.1 编写测试3.2 配置资源文件3.3 验证功能一、概述 本文档是针对x86 平台opencv的图像采集和seetaface6的性别识别功能,opencv通过摄像头采集视频图像,将采集的视频图像送给seetaface6的性别识别模块从而实现…

JS将class转换为function

类定义与构造函数 在JavaScript中&#xff0c;类的定义可以通过class关键字来实现&#xff0c;也可以通过传统的构造函数和原型链的方式来实现。上述代码展示了这两种不同的实现方式。 使用class关键字 class Example {constructor(name) {this.name name;}func() {console…

谓词和量词

一、个体词和谓词 命题是一句陈述句&#xff0c;命题由个体词和谓词组成。 个体词是句子中的主语部分&#xff0c;比如这里的王童。 谓词是句子里的剩余部分&#xff0c;比如是一个三好学生 个体词用小写字母表示&#xff0c;谓词用大写字母&#xff0b;&#xff08;&#…