百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

2022 把 Python 学得跟 Java 一样熟练——05 插入排序

off999 2024-10-27 11:51 15 浏览 0 评论

背景

翻到以前实现的一个 Java 插入排序算法,今天把它翻译成 Python ,练习并温故 Python 的基础语法:

  1. for in range 循环下标范围,从 0 开始,到 N-1 ,倒序遍历用 reversed
  2. 插入排序算法,找到当前元素应该插入的位置。

回忆 Java 的实现

Java 实现插入排序算法:

public class InsertSortUtil {
    public static void insertSort(int[] array) {
        // 插入排序:i从第二个元素开始,将它与a0..ai-1 这些元素比较,找到它应该插入的位置 position
        for (int i = 1; i < array.length; i++) {
            // 记录当前 i 的元素到临时变量
            int currentValue = array[i];

            // 当前记录所在的位置为 i
            int position = i;

            // 向前对比,找到当前元素确定的有序的位置
            for (int j = i - 1; j >= 0; j--) {
                // 如果某个位置的元素比当前元素大,那就将这个数据向后挪动,修正位置
                if (array[j] > currentValue) {
                    array[j + 1] = array[j];
                    position = j;
                } else {
                    break;
                }
            }

            // 将目标位置插入当前元素
            array[position] = currentValue;
        }
    }

    public static void main(String[] args) {
        int[] r = new int[20];
        for (int i = 0; i < r.length; i++) {
            r[i] = (int) (Math.random() * 20000);
        }

        System.out.println("before sort:"+Arrays.toString(r));
        insertSort(r);
        System.out.println("after sort:"+Arrays.toString(r));
    }
}

Python 实现插入排序

def insertSort(array):
	for i in range(1,len(array)):
		# 记录临时变量
		currentValue = array[i]
		position = i
		
		for j in reversed(range(i)):
			# 如果当前 j 位置的数值比当前值大,将其往后移动,修正当前记录的位置
			if (array[j] > currentValue):
				array[j+1] = array[j]
				position = j
			else:
				break
		
		# 插入当前元素
		array[position] = currentValue

# 测试
datas = [1,2,0,3,4,6,7,9]
print('before sort',datas)		
insertSort(datas)
print('after sort',datas)

插入排序的核心思想是将当前元素 a[i] 插入到前面 a[0..i-1] 中某个合适的位置,内层遍历是逆序范围为【i-1,0】,使用 reversed 函数来翻转数组。

运行结果:

启示录

消除模糊,今天弄透了两个 Python 知识点:

  1. 字符串的分片语法【start:end:step】,含头不含尾,这点跟 Java 语法一样。
  2. range(n) 得到的数组范围为 【0,n-1】,reversed 可以翻转数组。

相关推荐

Python写每天进步1%的力量(python计算每天进步一点点)

离别了学生时代,步入了职场,你还记得你离上一次打开书本是在什么时候吗?认真上课,看学习视频,静下心来,虽唾手可得,却似乎离我们越来越远。每天忙着忙着,不知道自己忙什么,只是连坐下来停下思考5分钟的时间...

Python高级特性揭秘:14个鲜为人知的编程秘籍

引言:Python的隐藏宝藏Python作为全球最受欢迎的编程语言之一,以其简洁和易用性著称。然而,许多开发者在日常工作中只触及了Python的表面,错过了许多强大而高效的高级特性。这些特性不仅能让代...

Python自动化脚本指南(pythonui自动化脚本)

以下是一个实用的Python自动化脚本指南,包含常见场景示例和分步说明:一、环境准备安装Python(推荐3.6+版本)安装常用库:bashpipinstallrequestsbea...

python面向对象四大支柱——多态(python面向对象总结)

Python面向对象多态(Polymorphism)详解多态是面向对象编程的四大支柱之一,它允许不同类的对象对同一消息(方法调用)做出不同的响应。下面我将全面详细地讲解Python中的多态概念及其实现...

主编推荐 | Gurobi 并行计算的设置和操作(附代码)

『运筹OR帷幄』原创作者:运筹OR帷幄编者按实际应用问题往往具有较高的计算复杂度,而优化算法难以在实际中落地的主要瓶颈就在于无法满足实际问题对计算时间的苛刻要求。然而近年来随着计算力的蓬勃发展,并行计...

Python 空值(None)详解(python 给空值赋值)

在Python中,空值是一个非常重要的概念,表示"没有值"或"空"的状态。让我们来详细了解一下。什么是空值?在Python中,空值用None表示。它是一个特殊的数据类型...

python学习——032关于函数接收的参数和返回值

在Python里,函数的参数和返回值都能是字符(字符串)、列表、字典等多种类型的数据,这大大提升了函数的灵活性和复用性。下面为举例说明:1.参数和返回值为字符串defgreet(name):...

一文理解 Python 中的类型提示(python 类的作用)

Python的流行源于其简洁性和可读性。然而,作为一种动态类型语言,其灵活性有时会导致运行时错误和由于数据类型不正确而出现意外行为。这是类型提示和静态类型检查发挥作用的地方,为Python代码...

新手学Python避坑,学习效率狂飙! 二十三、Python 闭包问题

感谢大家对《新手学Python避坑,学习效率狂飙!》系列的点赞、关注和收藏,今天这编是这个系列的第二十三个分享,前面还有二十二个,大家可以关注下之前发布的文章。下面是我们今天的分享:闭包的定义与原理在...

一个用 Rust 开发的极快、易用的 Python 包和项目管理利器

uv是一个全新的、由Astral团队(就是那个开发了Ruff的团队)采用Rust开发的高性能的Python包和项目管理工具。它的目标是取代传统的pip和pip-tools,提供...

脱颖而出的Python xlwings模块,一个更强大的操作Excel的模块

如下,在Python中存在很多支持Excel操作的第三方库,那么本文介绍的xlwings模块有其它模块有何区别呢?xrldxlwtopenpyxlxlswriterpandaswin32comxl...

一小时学会用Python开发微信AI机器人:从零到企业级应用实战

一、企业微信API接入流程:打造合法合规的机器人通道1.1企业微信与个人微信的区别企业微信三大优势:1.官方API支持(合规性保障)2.支持多终端消息同步3.可扩展企业级功能(审批/打卡...

Python 进阶-day24: API 开发(python的api)

学习目标理解RESTfulAPI的核心概念和设计原则。使用Flask创建模块化的RESTfulAPI,包含优雅的数据库访问代码。为博客应用实现API接口,支持CRUD操作(创建、...

PyQt5 库:强大的 Python GUI 开发利器

一、引言在Python的众多应用领域中,图形用户界面(GUI)开发是一个重要的方面。PyQt5库作为一个功能强大且广泛应用的GUI框架,为开发者提供了丰富的工具和组件,使得创建交互式、美观的...

探秘:Python 类为何继承 object(python中的类都继承于object)

在Python的编程世界里,我们常常会看到这样的代码:classMyClass(object):,这里的类继承了object。那么,Python类为什么要继承object呢?今天咱们...

取消回复欢迎 发表评论: