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/6 8:54:53

方才的系分架构训练营升级啦!别错过!

Hello&#xff0c;我是方才。先做个简单的自我介绍&#xff0c;认识下&#xff1a;【城市】重庆【职业|经验】在职15人研发leader 7年【架构经验】4年架构经验&#xff0c;负责过多个大型项目&#xff08;单表超10亿&#xff0c;整体超100亿的海量业务数据&#xff09;的架构设…

作者头像 李华
网站建设 2026/2/26 14:01:56

2026最新版Ubuntu安装Docker(20.10+)和Docker Compose

一、安装Docker 准备环境#安装前先卸载操作系统默认安装的docker&#xff0c; sudo apt-get remove docker docker-engine docker.io containerd runc#安装必要支持 sudo apt install apt-transport-https ca-certificates curl software-properties-common gnupg lsb-releas…

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

TOB企业获客软件选型指南:技术架构、方法论与实践评估

在数字化转型浪潮的推动下&#xff0c;TOB&#xff08;企业对企​​业&#xff09;企业的销售与市场模式正经历深刻变革。传统的电话销售、展会营销等线下获客方式成本高昂、效率瓶颈日益凸显&#xff0c;而线上渠道碎片化、数据孤岛等问题又为精准定位目标客户带来了巨大挑战。…

作者头像 李华
网站建设 2026/2/28 10:13:38

基于springboot + vue酒店管理系统

酒店管理管理 目录 基于springboot vue酒店管理系统 一、前言 二、系统功能演示 详细视频演示 三、技术选型 四、其他项目参考 五、代码参考 六、测试参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 基于springboot vue酒店管理系统 一、前言 博主介绍…

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

出口接地电阻柜需要注意什么

接地电阻柜&#xff0c;用于出口项目需要更加严谨。在操作、安装、维护及环境适应性方面需遵循严格规范&#xff0c;以确保电力系统安全稳定运行。以下结合关键注意事项进行说明。操作前需确认电源稳定性&#xff0c;检查接线正确性&#xff0c;避免短路或接触不良。‌同时&…

作者头像 李华