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

蓝桥杯备考冲刺必刷题(Python) | 3226 宝藏排序II

off999 2024-10-09 14:04 54 浏览 0 评论

学习Python从娃娃抓起!记录下蓝桥杯备考比赛学习过程中的题目,记录每一个瞬间。

附上汇总贴:蓝桥杯备考冲刺必刷题(Python) | 汇总-CSDN博客


【题目描述】

在一个神秘的岛屿上,有一支探险队发现了一批宝藏,这批宝藏是以整数数组的形式存在的。每个宝藏上都标有一个数字,代表了其珍贵程度。然而,由于某种神奇的力量,这批宝藏的顺序被打乱了,探险队需要将宝藏按照珍贵程度进行排序,以便更好地研究和保护它们。作为探险队的一员,肖恩需要设计合适的排序算法来将宝藏按照珍贵程度进行从小到大排序。请你帮帮肖恩。

【输入】

输入第一行包括一个数字n,表示宝藏总共有n个。

输入的第二行包括n个数字, 第i个数字a[i]表示第i个宝藏的珍贵程度。

数据保证1≤n≤10^5,1≤a[i]≤10^9。

【输出】

输出n个数字,为对宝藏按照珍贵程度从小到大排序后的数组。

【输入样例】

5
1 5 9 3 7

【输出样例】

1 3 5 7 9

【代码详解】

# 使用快速排序编写(与学而思教的l,r指针不一样)
n = int(input())  # 输入n
a = [int(i) for i in input().split()]  # 输入a列表

def partition(a, left, right):  # 找到mid值,并将mid左边放比mid小的,mid右边放比mid大的
    idx = left+1  # 定义要交换的下标
    for i in range(left+1, right+1):  # 从left+1遍历至right
        if a[i]<=a[left]:  # 如果比基准值a[left]要小
            a[i],a[idx] = a[idx],a[i]  # 与要交换的下标进行交换
            idx+=1  # idx自增1
    a[left],a[idx-1] = a[idx-1],a[left]  # 最后将基准值与idx-1进行交换
    return idx-1  # 返回idx-1,其为mid

def quick_sort(a, left, right):  # 递归搜索
    if left<right:  # 保证left小于right,否则就是1个数的情况
        mid = partition(a, left, right)  # 获得mid值
        quick_sort(a, left, mid-1)  # 将mid左半边继续递归排序
        quick_sort(a, mid+1, right)  # 将mid右半边继续递归排序

quick_sort(a, 0, n-1)  # 调用快排
for i in range(len(a)):  # 输入排序后的a列表
    print(a[i], end=" ")
# 使用归并排序编写
n = int(input())  # 输入n
a = [int(i) for i in input().split()]  # 输入a列表

def Merge(A, B):
    result = []  # 定义个空列表保存结果
    while len(A)!=0 and len(B)!=0:  # 当A列表与B列表同时不为空时
        if A[0]<=B[0]:  # 进行首元素比较,较小的添加到result列表中,并弹出
            result.append(A.pop(0))
        else:
            result.append(B.pop(0))
    result.extend(A)  # 最后将剩余的A列表和B列表追加到result中
    result.extend(B)
    return result  # 返回合并后的列表

def MergeSort(A):  # 递归方式将A列表进行 归操作
    if len(A)<2:  # 当长度为0或1时
        return A  # 返回
    mid = len(A)//2  # 获得一半的长度
    left = MergeSort(A[:mid])  # 列表左半边进行归操作
    right = MergeSort(A[mid:])  # 列表右半边进行归操作
    return Merge(left, right)  # 将左半边和右半边的列表进行 并操作

a = MergeSort(a)  # 对a列表调用归并排序
for i in range(len(a)):  # 输入排序后的a列表
    print(a[i], end=" ")
# 使用桶排序方式编写
n = int(input())  # 输入n
a = [int(i) for i in input().split()]  # 输入a列表

def BucketSort(A, bucketcount):  # 定义桶排序函数
    minvalue, maxvalue = min(A), max(A)  # 找到最大值和最小值
    bucketsize = (maxvalue-minvalue+1)//bucketcount  # 计算桶的大小
    res = [[] for i in range(bucketcount+1)]  # 初始化bucketcount+1个桶
    for x in A:  # 遍历A列表中所有元素
        idx = (x-minvalue)//bucketsize  # 确定其所属的桶的下标
        res[idx].append(x)  # 加入到对应的桶中
    ans = []  # 定义结果数组
    for res_x in res:  # 遍历每个桶
        res_x = sorted(res_x)  # 每个桶单独排序
        ans += res_x  # 再将排序后的结果添加到ans列表中
    return ans  # 返回ans列表

a = BucketSort(a, min(1000, n))  # 对a列表调用桶排序
for i in range(len(a)):  # 输入排序后的a列表
    print(a[i], end=" ")

【运行结果】

5
1 5 9 3 7
1 3 5 7 9 

相关推荐

Python Flask 容器化应用链路可观测

简介Flask是一个基于Python的轻量级Web应用框架,因其简洁灵活而被称为“微框架”。它提供了Web开发所需的核心功能,如请求处理、路由管理等,但不会强制开发者使用特定的工具或库。...

Python GUI应用开发快速入门(python开发软件教程)

一、GUI开发基础1.主流GUI框架对比表1PythonGUI框架比较框架特点适用场景学习曲线Tkinter内置库,简单小型应用,快速原型平缓PyQt功能强大,商用许可专业级桌面应用陡峭PySi...

【MCP实战】Python构建MCP应用全攻略:从入门到实战!

实战揭秘:Python Toga 打造跨平台 GUI 应用的神奇之旅

在Python的世界里,GUI(图形用户界面)开发工具众多,但要找到一款真正跨平台、易于使用且功能强大的工具并不容易。今天,我们就来深入探讨一下Toga——一款Python原生、操作系统原...

python应用目录规划(python的目录)

Python大型应用目录结构规划(企业级最佳实践)核心原则模块化:按业务功能拆分,高内聚低耦合可扩展性:支持插件机制和动态加载环境隔离:清晰区分开发/测试/生产环境自动化:内置标准化的构建测试部署流...

Python图形化应用开发框架:PyQt开发简介

PyQt概述定义:PyQt是Python绑定Qt框架的工具集,用于开发跨平台GUI应用程序原理:通过Qt的C++库提供底层功能,PyQt使用SIP工具生成Python绑定特点:支持Windows/ma...

[python] 基于PyOD库实现数据异常检测

PyOD是一个全面且易于使用的Python库,专门用于检测多变量数据中的异常点或离群点。异常点是指那些与大多数数据点显著不同的数据,它们可能表示错误、噪声或潜在的有趣现象。无论是处理小规模项目还是大型...

Python、Selenium 和 Allure 进行 UI 自动化测试的简单示例脚本

环境准备确保你已经安装了以下库:SeleniumAllurepytest你可以使用以下命令安装所需库:pipinstallseleniumallure-pytestpytest示例代码下面的代...

LabVIEW 与 Python 融合:打造强大测试系统的利器

在现代测试系统开发领域,LabVIEW和Python各自凭借独特优势占据重要地位。LabVIEW以图形化编程、仪器控制和实时系统开发能力见长;Python则凭借丰富的库资源、简洁语法和强大数...

软件测试进阶之自动化测试——python+appium实例

扼要:1、了解python+appium进行APP的自动化测试实例;2、能根据实例进行实训操作;本课程主要讲述用python+appium对APP进行UI自动化测试的例子。appium支持Androi...

Python openpyxl:读写样式Excel一条龙,测试报表必备!

无论你是测试工程师、数据分析师,还是想批量导出Excel的自动化工作者,只需一个库openpyxl,即可高效搞定Excel的各种需求!为什么选择openpyxl?支持.xlsx格式...

Python + Pytest 测试框架——数据驱动

引言前面已经和大家介绍过Unittest测试框架的数据驱动框架DDT,以及其实现原理。今天和大家分享的是Pytest测试框架的数据驱动,Pytest测试框架的数据驱动是由pytest自...

这款开源测试神器,圆了我玩游戏不用动手的梦想

作者:HelloGitHub-Anthony一天我在公司用手机看游戏直播,同事问我在玩什么游戏?我和他说在看直播,他恍然大悟:原来如此,我还纳闷你玩游戏,咋不用动手呢。。。。一语惊醒梦中人:玩游戏不用...

Python单元测试框架对比(pycharm 单元测试)

一、核心框架对比特性unittest(标准库)pytest(主流第三方)nose2(unittest扩展)doctest(文档测试)安装Python标准库pipinstallpytestp...

利用机器学习,进行人体33个2D姿态检测与评估

前几期的文章,我们分享了人脸468点检测与人手28点检测的代码实现过程,本期我们进行人体姿态的检测与评估通过视频进行人体姿势估计在各种应用中起着至关重要的作用,例如量化体育锻炼,手语识别和全身手势控制...

取消回复欢迎 发表评论: