news 2026/4/15 9:35:44

python编程实战(三)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
python编程实战(三)

题目1:

给你一个整数数组nums,返回 数组answer,其中answer[i]等于nums中除nums[i]之外其余各元素的乘积 。

题目数据保证数组nums之中任意元素的全部前缀元素和后缀的乘积都在32 位整数范围内。

不要使用除法,且在O(n)时间复杂度内完成此题。

关键数据结构:

列表(一维数组)

核心思路:

除nums[i]元素之外的元素乘积可以分为两部分,nums[i]之前的元素的乘积和nums[i]之后的元素的乘积;将数组num正向遍历一遍之后,可以再反向遍历一遍,然后用一个数组先存储前元素乘积,再存储后元素乘积。

代码:

class Solution:
def productExceptSelf(self, nums: List[int]) -> List[int]:
n = len(nums)
ans = [1] * n
# 从左到右计算前缀积
prefix = 1
for i in range(n):
ans[i] = prefix
prefix *= nums[i]
# 从右到左计算后缀积并乘以结果
suffix = 1
for i in range(n - 1, -1, -1):
ans[i] *= suffix
suffix *= nums[i]
return ans

题目2:

给你一个未排序的整数数组nums,请你找出其中没有出现的最小的正整数。

请你实现时间复杂度为O(n)并且只使用常数级别额外空间的解决方案。

关键数据结构:
用列表实现哈希表效果

关键思路:
原地哈希算法,我们希望在位置i上的值是i+1,如在位置0上的位置是1,这样可以起到高效的排序效果;如果位置i上的数!=i+1,那么此时的i+1就是缺失的最小正整数。

代码:
class Solution:
def firstMissingPositive(self, nums: List[int]) -> int:
n = len(nums)
for i in range(n):
while 1 <= nums[i] <= n and nums[nums[i] - 1] != nums[i]:
target_idx = nums[i] - 1
nums[i], nums[target_idx] = nums[target_idx], nums[i]

for i in range(n):
if nums[i] != i + 1:
return i + 1

return n + 1

题目3:

给定一个mxn的矩阵,如果一个元素为 0 ,则将其所在行和列的所有元素都设为 0 。请使用原地算法(原地算法是指在算法执行过程中,只使用常数量级的额外空间,主要通过对输入数据的原有存储空间进行修改来完成计算,而不需要额外的数据结构来存储中间结果或输出结果)。

关键数据结构:

二维数组

思路:

使用双循环遍历矩阵每个元素,如果某个元素为0,将其对应的行、列通过布尔值打上标记;再次双循环遍历矩阵,如果某一行或者某一列标记为零,将整行或整列元素置0

代码(这里偷懒没用原地算法):

class Solution:
def setZeroes(self, matrix: List[List[int]]) -> None:
m, n = len(matrix), len(matrix[0])
row = m * [False]
col = n * [False]

for i in range(m):
for j in range(n):
if matrix[i][j] == 0:
row[i] = True
col[j] = True

for i in range(m):
for j in range(n):
if row[i] or col[j]:
matrix[i][j] = 0

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/13 13:32:52

嵌入式开发的核心工具

在嵌入式开发中&#xff0c;开发工具直接影响编码效率、调试体验和项目管理能力。接下来我们从嵌入式场景适配性出发&#xff0c;详细介绍 VSCode、Qt、Keil、Vim 四大工具的核心功能、优缺点、适用场景及配置要点&#xff0c;帮你根据需求选择合适的工具链。 一、VSCode&…

作者头像 李华
网站建设 2026/4/11 9:03:29

基于SpringBoot的高校迎新管理系统毕业设计项目源码

题目简介 在高校迎新工作规模化、智能化需求升级的背景下&#xff0c;传统迎新存在 “流程繁琐、信息核验慢、数据统计滞后” 的痛点&#xff0c;基于 SpringBoot 构建的高校迎新管理系统&#xff0c;适配学校迎新办、各院系、新生及家长等多角色&#xff0c;实现迎新全流程&am…

作者头像 李华
网站建设 2026/4/12 14:24:44

名词解释:数据负载

使用工作者线程时&#xff0c;经常需要为它们提供某种形式的数据负载。数据负载是什么意思&#xff1f;数据负载&#xff08;Data Payload&#xff09;指的是在线程间传递的数据内容或工作任务的具体信息。在工作者线程的上下文中&#xff0c;它通常指从主线程传递给工作者线程…

作者头像 李华
网站建设 2026/4/14 2:38:24

基于SpringBoot的足球队管理系统毕业设计项目源码

题目简介在业余 / 校园足球队规范化运营、训练赛事精细化管理需求升级的背景下&#xff0c;传统足球队管理存在 “人员信息散乱、训练赛事无记录、后勤管理低效” 的痛点&#xff0c;基于 SpringBoot 构建的足球队管理系统&#xff0c;适配球队管理员、教练、球员等多角色&…

作者头像 李华
网站建设 2026/4/14 16:03:02

AP0316 USB接口:工业级语音模组核心技术解析

在语音模组的接口选型中&#xff0c;USB凭借其通用性与便捷性成为连接主流计算平台的首选方案。AP0316作为一款面向全场景的高性能语音处理模组&#xff0c;其集成的USB 2.0接口并非简单的通信通道&#xff0c;而是融合了音频协议优化、工业级稳定性设计与多系统适配能力的核心…

作者头像 李华
网站建设 2026/4/13 21:21:53

基于SpringBoot的中医药销售系统毕业设计项目源码

题目简介在中医药产业规范化、数字化销售需求升级的背景下&#xff0c;传统中医药销售存在 “药材溯源难、库存管控低效、处方调配繁琐” 的痛点&#xff0c;基于 SpringBoot 构建的中医药销售系统&#xff0c;适配药店、中医院、中药材供应商、消费者等多角色&#xff0c;实现…

作者头像 李华