news 2026/3/8 2:09:53

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/3/7 21:44:57

基于SpringBoot的自动驾驶数据处理任务众包平台系统毕业设计项目源码

题目简介 在自动驾驶技术研发阶段&#xff0c;海量数据标注 / 处理需求与专业人力不足的矛盾突出&#xff0c;传统数据处理模式存在 “任务分配低效、质量管控难、结算不透明” 的痛点。基于 SpringBoot 构建的自动驾驶数据处理任务众包平台&#xff0c;适配算法研发团队、众包…

作者头像 李华
网站建设 2026/3/7 3:06:52

基于SpringBoot的养老院管理系统毕业设计项目源码

题目简介在养老服务精细化、智能化需求升级的背景下&#xff0c;传统养老院管理存在 “老人照护记录零散、服务调度低效、家属沟通不畅” 的痛点&#xff0c;基于 SpringBoot 构建的养老院管理系统&#xff0c;适配院方管理员、护理人员、老人及家属等多角色&#xff0c;实现老…

作者头像 李华
网站建设 2026/3/7 19:32:55

若是Windows下的HGDB配置参数work_mem>=2GB会导致HGDB服务无法启动

文章目录环境症状问题原因解决方案环境 系统平台&#xff1a;Microsoft Windows (64-bit) 10 版本&#xff1a;5.6.3 症状 Windows下的HGDB&#xff0c;配置参数work_mem>2GB会导致HGDB服务无法启动&#xff0c;如下报错来自于windows的“计算机管理”-“事件查看器”-“…

作者头像 李华
网站建设 2026/3/7 23:27:35

17、使用psad应对网络攻击:原理、配置与实例

使用psad应对网络攻击:原理、配置与实例 1. TCP连接攻击检测 在已建立的TCP连接中检测攻击,需要检测系统维护一个已建立连接的表,并在这些连接中查找攻击。虽然可以伪造具有逼真序列号和确认号的TCP数据包,但这些数据包并非真正已建立连接的一部分,检测机制需要判断这一点…

作者头像 李华
网站建设 2026/3/5 6:16:43

EmotiVoice能否替代真人配音?实测对比告诉你

EmotiVoice能否替代真人配音&#xff1f;实测对比告诉你 在短视频日更、播客爆发、游戏剧情日益复杂的今天&#xff0c;内容创作者们正面临一个共同难题&#xff1a;如何快速、低成本地获得高质量的语音输出&#xff1f;传统的真人配音虽然自然生动&#xff0c;但动辄几千元每小…

作者头像 李华
网站建设 2026/3/5 20:09:44

EmotiVoice语音紧迫感调控适合警报通知

EmotiVoice&#xff1a;让警报语音真正“被听见”的情感化合成引擎 在地铁站台刺耳的广播中&#xff0c;你是否曾因语气平淡而错过关键信息&#xff1f;在车载导航提示“前方急弯”时&#xff0c;是否觉得它和“附近有加油站”一样无关紧要&#xff1f;这些日常体验背后&#…

作者头像 李华