python 基础知识点(蓝桥杯python科目个人复习计划49)

今日复习内容:做复习题

例题1:希尔排序

题目描述:

希尔排序是直接插入排序算法的一种更高效的改进版本,但它是非稳定排序算法。希尔排序是基于插入排序的以下两点性质而提出的改进方法之一:

1.插入排序在对几乎已经排好序的数据操作时,效果是非常好的。

2.插入排序一般来说是低效的,因为插入排序每次只能将数据移动一位。

而通常对于希尔排序中我们选择增量序列为:[N / 2],[N / 4],...,1,其中N为待排序数组的长度。

现在,给你一个整数数组,要求使用希尔排序算法对它进行排列。

输入格式:

第一行是一个整数n,表示整数数组的长度;

第二行包含n个空格分隔的整数a1,a2,...,an。

输出格式:

输出n个整数,即从小到大排序后的数组。

参考答案:

n = int(input())
li = list(map(int,input().split()))
gap = n // 2
while gap:for i in range(gap,n):value = li[i]j = iwhile j >= gap:if li[j - gap] > value:li[j] = li[j - gap]j -= gapelse:breakli[j] = valuegap //= 2
print(*li)

运行结果:

以下是我对这道题的理解:

这个问题要求使用希尔排序算法对给定的整数数组进行排序。

希尔排序是插入排序的一种改进版本,它通过引入增量序列来减少插入排序中元素比较和交换的次数,从而提高排序效率。希尔排序的核心思想是先将整个待排序的记录序列分割成若干子序列,分别进行直接插入排序,待整个序列中的记录基本有序时,再对全体记录进行直接插入排序。

而希尔排序的增量序列是选择一个递减的序列,通常为N / 2,N / 4,...,1,其中N是待排序数组的长度。

首先,输出整数数组的长度和具体的数组内容。然后,初始化增量为数组长度的一半。接下来,通过一个while循环,不断缩小增量,直到增量为0。在循环中,对每个增量间隔进行插入排序。在插入排序中,从第一个增量间隔开始,将当前待插入的值与前面的值进行比较,依次向前移动元素,直到找到合适的位置插入。最后,输出排序后的数组。

n = int(input()):我们从标准输入中获取一个整数,表示整段数组的长度,将其赋值给变量n.

li = list(map(int,input().split())):接着,我们再从标准输入中读取一行,包含了空格分隔的整数,使用split()函数将其分隔成单独的数字字符串,并通过map()函数将这些字符串转换成整数,最后把它们组成一个列表并赋值给变量li,表示整数数组。

gap = n // 2 :然后,我们初始化增量gap为数组长度的一半。希尔排序中,我们会根据增量序列进行分组,首先选择一个较大的增量。

while gap:这里是一个while循环,只有增量gap不为0,就会一直执行排序

for i in range(gap,n):在每次循环中,我们使用for循环变量从gap开始到数组长度n的范围,这是为了对增量间隔进行排序。

value = li[i]:我们将当前待插入的值存储在变量value中,即当前增量间隔内需要插入到正确位置的元素

j = i:然后,我们将变量j初始化为当前位置i,从当前位置开始向前比较

while j >= gap and li[j -  gap] > value:这是一个while循环,它会在满足两个条件的情况下执行:

j >= gap:然后,确保我们没有越界访问数组;

li[j -  gap] > value:比较当前位置的前一个间隔增量的值是否大于待插入的值value,如果是,则需要向后移动元素。

li[j] = li[j - gap]:如果满足条件,我们将前一个间隔增量的值向后移动要给位置。

j -= gap:然后,我们将j向前移动 一个间隔增量,继续向前比较

li[j] = value:最后,我们将待插入的值value插入到正确的位置

gap //= 2:在内层循环结束后,我们将增量gap减半,以减少增量,这是希尔排序的一个重要步骤

print(*li):最后,我们使用print函数输出最后的数组,通过*li,我们将列表li中的元素拆包传递给print()函数,以便按照空格分隔输出数组元素。

通过对每个间隔增量进行插入排序,并在每轮排序或缩小增量,最终完成整个数组的排序。


例题2:图书排序

题目描述:

城市图书馆决定对其藏书进行重新分类。它们决定使用希尔排序作为其分类方法的基础,但是有一些特殊的要求。

图书馆的每本书都有一个独特的ID,范围从1到N。每本书还有一个权重值,表示其在库中的重要性。图书馆希望按照权重对图书进行排列,但是他们希望保留希尔排序的某些特性。

他们的要求如下:

1.使用希尔排序的增量序列:[N / 2],[N / 4],...,1。

2.当两本书的权重相同时,书籍ID较小的书应该出现在前面。

你的任务是根据这些要求,为图书馆排序这些藏书。

输入格式:

第一行,一个整数N,表示图书的数量。

接下来的N行,每行两个整数,分别是书籍的ID和权重,题目保证每本书的ID是唯一的。

输出格式:

输出N行,每行一个整数,按权重排序后的书籍ID。

参考答案:

n = int(input())
li = []
for i in range(n):li.append(list(map(int,input().split())))
gap = n // 2
while gap:for i in range(gap,n):value = li[i]j = iwhile j >= gap:if li[j - gap][1] > value[1]:li[j] = li[j - gap]j -= gapelse:breakli[j] = valuegap //= 2
for i in li:print(i[0])

运行结果:

以下是我对代码的理解:

n = int(input()):首先,我们从标准输入中读取一个整数n,表示图书的数量,将其赋值给n

li = []:然后,我们初始化一个空列表li用来存储每本图书的信息。每个元素是一个包含两个整数的列表,分别表示书籍的ID和权重。

for i in range(n):接着,我们使用for循环遍历n次,读取每本书的ID和权重,并将其作为一个包含两个整数的列表添加到列表li中。

gap //= 2:初始化希尔排序的增量为数组长度n的一半

while gap:这是一个while循环,只要增量gap不为0,循环就会一直运行下去

for i in range(gap,n):在每次循环中,我们使用for循环遍历从增量gap开始到数组长度n的范围,这是为了对每个增量间隔进行插入排序

value = li[i]:我们将当前待插入的图书信息存储在变量value中,即当前增量间隔内需要插入到正确位置的书籍。

j = i:然后,我们把变量j初始为当前位置i,从当前位置开始向前比较

while j >= gap:这是一个while循环,它会在满足条件 j >= gap的情况下执行,确保我们没有越界访问数组。

if li[j - gap][1] > value[1]:在循环中,我们比较当前位置的前一个间隔增量的书籍 权重是否大于待插入书籍的权重

li[j] = li[j - gap]:如果前一个间隔增量的权重较大,我们将其向后移一个位置

j -= gap:然后,我们将j向前移动一个间隔增量,继续向前比较

else:break:如果前一个间隔增量的书籍权重不大于待插入的书籍权重,则跳出循环,因为我们要保持相同权重的情况下ID较小的排前面。

li[j] = value:最终,我们将待插入的书籍信息插入到正确位置

gap //= 2:在内层循环结束后,我们将增量gap减半,以缩小增量,这是希尔排序的一个重要步骤

for i in li:最后,我们使用for循环遍历排序后的书籍信息列表li

print(i[0]):通过print()函数输出每本书的ID,这样就满足了题目要求,按照权重排序,并在权重相同时,保留ID较小的书籍在前面。


例题3:咖啡馆订单系统

题目描述:

一家知名的连锁咖啡馆决定改进其订单管理系统。为了提高效率,他们决定使用某种指定属性的希尔排序,并确定在给定的增量序列下,需要多少次比较和交换对订单进行排序。

输入格式:

第一行,一个整数n,表示订单的数量。

第二行,一个整数m,表示增量序列的长度。

接下来的一行,包含m个以空格分开的整数,表示增量序列,题目保证增量序列严格递减且最后一个数是1.

接下来的n行,每行一个整数,表示订单的属性值。

输出格式:

两个整数,分别表示比较和交换的次数。

参考答案:

n = int(input())
m = int(input())
gaps = list(map(int,input().split()))
compare = 0
change = 0
li = []
for i in range(n):li.append(int(input()))
for gap in gaps:for i in range(gap,n):value = li[i]j = iwhile j >= gap:compare += 1if li[j - gap] > value:change += 1li[j] = li[j - gap]j -= gapelse:breakli[j] = value
print(compare,change)

运行结果:

以下是我对此题的理解:

n = int(input()):从标准输入中读取订单数量n,将其转换为整数并赋值给变量n

m = int(input()):从标准输入中读取增量序列的长度m,将其转换为整数并赋值给变量m

gaps = list(map(int,input().split())):从标准输入读取一行,使用split()函数将其分割成字符串序列,然后使用map()函数将其转换为整数,再将其转换为列表赋值给gaps

compare = 0和change = 0:初始化比较次数和交换次数为0

li = []:初始化一个空列表,用于存储订单的属性值

for i in range(n):循环n次,读取每个订单的属性值,并将其作为整数添加到列表li中

for gap in gaps:遍历增量序列中的每个增量

for i in range(gap,n):从增量gap开始,遍历订单列表进行排序

value = li[i] :将当前位置的订单属性值存储在变量value中,,用于后续比较和插入操作

j = i:将变量j初始化为当前变量i,用于向前比较和插入操作

while j >= gap:只要当前位置大于等于增量gap,就执行以下操作:

compare += 1:增加比较次数

li[j] = li[j - gap]:将前一个位置的属性值想后移动一位

j -= gap:将索引j向前移动一个增量gap的位置

else:break:如果不满足上述条件,就跳出循环

li[j] = value:将当前值value插入到正确的位置

print(compare,change):输出比较和交换次数


例题4:第3大的和

题目描述:

现在给定N个数,现在要求你从这N个数中挑选处理3个数,请你求出这3个数的和中第3大的是多少?

请注意,如果在求和过程中出现了相同的和,则只能留一个,其他的忽略不计。

输入格式:

输入的第一行包含一个整数n,表示数字的数量;

输入的第2行包含n个数字,代表给出的数字序列。

输出格式:

输出一行,包含一个数字,表示第3大的和。

参考答案:

import itertools
import heapq
n = int(input())
li = list(map(int,input().split()))
res = set()
for i in itertools.combinations(li,3):print(i)res.add(sum(i))
res = list(res)
print(heapq.nlargest(3,res))
print(heapq.nlargest(3,res)[-1])

运行结果:

以下是我对此题的理解:

import itertools:导入python中的itertools模块,用于生成序列的所有可能组合

import heapq:导入python中的heapq模块,用于堆操作,这里用于找出列表中的最大值

n = int(input()):从输入中读取一个整数,表示数字的数量,赋值给变量n

li = list(map(int,input().split())):从标准输入中读取一行数字,使用split()方法将其分割成单独的字符串列表,然后转换为整数,再转换为列表,赋值给变量li

res = set():初始化一个空集合,用于存储所有可能的和

for i in itertools.combinations(li,3):生成列表li中任意3个数字的组合,每次循环得到一个组合i

res.add(sum(i)):计算组合i的数字之和,并将其添加到集合set中

res = list(res):将集合转换为列表,为了后续使用heapq模块找出最大的3个值

print(heapq.nlargest(3,res)[-1]):找出前3大的和中的第3大值,即倒数第一个值,然后打印出来作为答案。


例题5:基数排序

题目描述:

实现基数排序算法。基数排序的介绍如下:

1.将整数按数位切割,然后将数值统一为同样的数位长度,数位较短的数前面补0;

2.从最低位开始,依次进行依次排序;

3.从最低位排序一直到最高位排序完成以后,数列就变成一个有序序列。

请编写代码,完成排序,对给定数据进行升序排列。

输入描述:

第一行,数字N(2 <= N<=100),表示待排序的元素个数。

第二行,待排序的元素。

输出描述:

输出一行,为升序序列。

参考答案:

n = int(input())
li = list(map(int,input().split()))
max_len = len(str(max(li)))
for i in range(n):li[i] = str(li[i])li[i] = '0' * (max_len - len(li[i])) + li[i]
for i in range(max_len - 1,-1,-1):li.sort(key = lambda x:x[i])
print(*list(map(int,li)))

运行结果:

以下是我对此题的理解:

 n = int(input()):从标准输入中读取一个整数n,表示待排序的元素个数

li = list(map(int,input().split()))

max_len = len(str(max(li))):计算列表li中最大元素的位数,将其转化为字符串再求长度,得到最大的位数,并赋值给变量max_len。

for i in range(n):变量li中的每个元素

li[i] = str(li[i]):将当前元素转换为字符串

li[i] = '0' * (max_len - len(li[i])) + li[i]:将当前元素的字符串表示补齐到最大位数,前面用0填充

接下来逆序遍历每一位

li.sort(key = lambda x:x[i]):使用列表的sort方法,根据当前位i进行排序

最后输出。


OK,这篇就写到这里,下一篇继续!

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

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

代码随想录算法训练营第四十天|343. 整数拆分 96.不同的二叉搜索树

343. 整数拆分 链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 思路: 动态规划的题目虽然说是要先确定dp数组的含义&#xff0c;再确定递归公式&#xff0c;但是总感觉这两者是相辅相成的&#xff0c;是一起出来的&#xff0c;但是到此&#xff0c;dp数组…

kubernetes负载均衡部署

目录 1.新master节点的搭建 对master02进行初始化配置&#xff08;192.168.88.31&#xff09; 将master01的配置移植到master02 修改master02配置文件 2.负载均衡的部署 两台负载均衡器配置nginx 部署keepalived服务 所有node节点操作 总结 实验准备&#xff1a; k8s…

开源大语言模型作为 LangChain 智能体

概要 开源大型语言模型 (LLMs) 现已达到一种性能水平&#xff0c;使它们适合作为推动智能体工作流的推理引擎: Mixtral 甚至在我们的基准测试中 超过了 GPT-3.5&#xff0c;并且通过微调&#xff0c;其性能可以轻易的得到进一步增强。 引言 针对 因果语言建模 训练的大型语言模…

QEMU之CPU虚拟化

概述 KVM是由以色列初创公司Qumranet在CPU推出硬件虚拟化之后开发的一个基于内核的虚拟机监控器。 KVM是一个虚拟化的统称方案&#xff0c;除了x86外&#xff0c;ARM等其他架构也有自己的方案&#xff0c;所以KVM的主体代码位于内核树virt/kvm目录下面&#xff0c;表示所有CP…

9、使用 ChatGPT 的 GPT 制作自己的 GPT!

使用 ChatGPT 的 GPT 制作自己的 GPT! 想用自己的 GPT 超越 GPT ChatGPT 吗?那么让我们 GPT GPT 吧! 山姆 奥特曼利用这个机会在推特上宣传 GPTs 的同时还猛烈抨击了埃隆的格罗克。 GPTs概览 他们来了! 在上周刚刚宣布之后,OpenAI 现在推出了其雄心勃勃的新 ChatGPT…

<网络安全>《49 网络攻防专业课<第十三课 - 华为防火墙的使用(2)>

6 防火墙的防范技术 6.1 ARP攻击防范 攻击介绍 攻击者通过发送大量伪造的ARP请求、应答报文攻击网络设备&#xff0c;主要有ARP缓冲区溢出攻击和ARP拒绝服务攻击两种。 ARP Flood攻击&#xff08;ARP扫描攻击&#xff09;&#xff1a;攻击者利用工具扫描本网段或者跨网段主机时…

eureka 简介和基本使用

Eureka 是Netflix开发的服务发现框架&#xff0c;是Spring Cloud微服务架构中的一部分。它主要用于微服务架构中的服务注册与发现。Eureka由两部分组成&#xff1a;Eureka Server 和 Eureka Client。获取更详细的信息可以访问官网&#xff0c;如下图&#xff1a; Eureka Server…

【vue】如何打开别人编译后的vue项目

文件结构如下&#xff0c;编译后的文件放在dist中。 dist的文件结构大约如下&#xff0c;文件名称随项目 1.新建app.js文件 const express require(express);const app express();const port 8080;app.use(express.static(dist));app.listen(port, () > console.log); …

【软件测试】定位前后端bug总结+Web/APP测试分析

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 1、Web测试中简单…

Vue监听器(上)之组合式watch

1. 定义监听器 //要监视的属性被改变时触发 watch(要监视的属性, (更改后的心值, 更改前的旧值) > {具体操作}, );//监视对象为getter的时候 //表达式内任意响应式属性被改变时触发 watch(() > return表达式, (表达式的新值, 表达式的旧值) > {具体操作} );//数组中任…

Redis篇之Redis持久化的实现

持久化即把数据保存到可以永久保存的存储设备当中&#xff08;磁盘&#xff09;。因为Redis是基于内存存储数据的&#xff0c;一旦redis实例当即数据将会全部丢失&#xff0c;所以需要有某些机制将内存中的数据持久化到磁盘以备发生宕机时能够进行恢复&#xff0c;这一过程就称…

Unity之PUN2插件实现多人联机射击游戏

目录 &#x1f4d6;一、准备工作 &#x1f4fa;二、UI界面处理 &#x1f4f1;2.1 登录UI并连接PUN2服务器 &#x1f4f1;2.2 游戏大厅界面UI &#x1f4f1;2.3 创建房间UI &#x1f4f1;2.4 进入房间UI &#x1f4f1;2.5 玩家准备状态 &#x1f4f1;2.6 加载战斗场景…

【深度学习】微调通义千问模型:LoRA 方法,微调Qwen1.8B教程,实践

官网资料: https://github.com/QwenLM/Qwen/blob/main/README_CN.md 文章目录 准备数据运行微调设置网络代理启动容器执行 LoRA 微调修改 finetune/finetune_lora_single_gpu.sh运行微调 执行推理 在本篇博客中&#xff0c;我们将介绍如何使用 LoRA 方法微调通义千问模型&#…

Docker Container(容器)

"在哪里走散&#xff0c;你都会找到我~" Docker 容器 什么是容器&#xff1f; 通俗来讲&#xff0c;容器是镜像运行的实体。我们对于镜像的认知是&#xff0c;“存储在磁盘上的只读文件”。当我们启动一个容器的本质&#xff0c;就是启动一个进程&#xff0c;即容器…

SpringBoot实现缓存预热的几种常用方案

&#x1f3f7;️个人主页&#xff1a;牵着猫散步的鼠鼠 &#x1f3f7;️系列专栏&#xff1a;Java全栈-专栏 &#x1f3f7;️个人学习笔记&#xff0c;若有缺误&#xff0c;欢迎评论区指正 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&…

【自然语言处理-二-attention注意力 是什么】

自然语言处理二-attention 注意力机制 自然语言处理二-attention 注意力记忆能力回顾下RNN&#xff08;也包括LSTM GRU&#xff09;解决memory问题改进后基于attention注意力的modelmatch操作softmax操作softmax值与hidder layer的值做weight sum 计算和将计算出来的和作为memo…

从零开始 TensorRT(5)C++ 篇:g++、CMake、VS Code 环境入门

前言 学习资料&#xff1a; B站视频&#xff1a;基于 VSCode 和 CMake 实现 C/C 开发 B站视频&#xff1a;Cherno C 教程 从本文开始&#xff0c;正式进入 C 部分。由于个人 C 零基础&#xff0c;仅了解一些 Python&#xff0c;所以学习时的痛点更偏向于 C 的基础&#xff0c;…

nios ii开发随笔

错误一&#xff1a; d:/intelfpga/17.1/nios2eds/bin/gnu/h-x86_64-mingw32/bin/../lib/gcc/nios2-elf/5.3.0/../../../../../H-x86_64-mingw32/nios2-elf/bin/ld.exe: test.elf section .text will not fit in region ram_oc_xzs d:/intelfpga/17.1/nios2eds/bin/gnu/h-x86_6…

01_第一章 WEB开发概述(技术栈,交互模式,CS和BS模式,前后端分离)

文章目录 第一章 WEB概述1.1 JAVAWEB简介1.2 JAVAWEB技术栈1.3 JAVAWEB交互模式1.4 JAVAWEB的CS和BS模式1.5 JAVAWEB实现前后端分离 第一章 WEB概述 1.1 JAVAWEB简介 用Java技术来解决相关web互联网领域的技术栈.使用JAVAEE技术体系开发企业级互联网项目. 项目规模和架构模式与…

Linux:ACL权限,特殊位和隐藏属性

目录 一.什么是ACL 二.操作步骤 ① 添加测试目录、用户、组&#xff0c;并将用户添加到组 ② 修改目录的所有者和所属组 ③ 设定权限 ④ 为临时用户分配权限 ⑤ 验证acl权限 ⑥ 控制组的acl权限 三. 删除ACL权限 一.什么是ACL 访问控制列表 (Access Control List):ACL 通…