news 2026/3/1 4:40:59

LeetCode数组题解:5大经典Python实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode数组题解:5大经典Python实战

以下是针对LeetCode热门题目Top 100 Liked Questions中“普通数组”类题目的Python版本解法指南。普通数组题目通常涉及数组的基本操作,如遍历、排序、查找等。我将逐步介绍几个代表性题目,提供Python代码和简要解释,帮助您理解和实现。

1. Two Sum(两数之和)

题目描述:给定一个整数数组nums和一个目标值target,在数组中找出和为目标值的两个整数,并返回它们的下标。假设只有一个有效解,且不能使用同一个元素两次。

Python解法

def twoSum(nums, target): num_map = {} for i, num in enumerate(nums): complement = target - num if complement in num_map: return [num_map[complement], i] num_map[num] = i return []

代码解释

  • 使用哈希表num_map存储每个元素的值和下标。
  • 遍历数组,计算当前元素的补数(target - num)。
  • 如果补数在哈希表中,直接返回下标对。
  • 时间复杂度:$O(n)$,空间复杂度:$O(n)$。

2. Maximum Subarray(最大子数组和)

题目描述:给定一个整数数组nums,找出连续子数组的最大和。

Python解法

def maxSubArray(nums): max_sum = float('-inf') current_sum = 0 for num in nums: current_sum = max(num, current_sum + num) max_sum = max(max_sum, current_sum) return max_sum

代码解释

  • 初始化max_sum为负无穷和current_sum为0。
  • 遍历数组,更新current_sum为当前元素或当前元素加上之前的子数组和的最大值。
  • 同时更新max_sum为当前最大值。
  • 时间复杂度:$O(n)$,空间复杂度:$O(1)$。

3. Move Zeroes(移动零)

题目描述:给定一个数组nums,将所有0移动到数组末尾,同时保持非零元素的相对顺序。

Python解法

def moveZeroes(nums): non_zero_idx = 0 for i in range(len(nums)): if nums[i] != 0: nums[non_zero_idx], nums[i] = nums[i], nums[non_zero_idx] non_zero_idx += 1

代码解释

  • 使用双指针:non_zero_idx指向非零元素应放置的位置。
  • 遍历数组,当遇到非零元素时,将其与non_zero_idx位置的元素交换,并移动指针。
  • 时间复杂度:$O(n)$,空间复杂度:$O(1)$。

4. Container With Most Water(盛最多水的容器)

题目描述:给定一个整数数组height,表示垂直线的高度,找出两条线与x轴形成的容器能容纳的最大水量。

Python解法

def maxArea(height): left, right = 0, len(height) - 1 max_area = 0 while left < right: width = right - left h = min(height[left], height[right]) max_area = max(max_area, width * h) if height[left] < height[right]: left += 1 else: right -= 1 return max_area

代码解释

  • 使用双指针从数组两端向中间移动。
  • 计算当前指针位置形成的容器面积(宽度乘以最小高度)。
  • 更新最大面积,并根据高度移动指针。
  • 时间复杂度:$O(n)$,空间复杂度:$O(1)$。

5. Product of Array Except Self(除自身以外数组的乘积)

题目描述:给定一个数组nums,返回一个数组,其中每个元素是除自身外所有元素的乘积。要求不使用除法,并在$O(n)$时间内完成。

Python解法

def productExceptSelf(nums): n = len(nums) left_products = [1] * n right_products = [1] * n answer = [1] * n # 计算左侧乘积 for i in range(1, n): left_products[i] = left_products[i-1] * nums[i-1] # 计算右侧乘积 for i in range(n-2, -1, -1): right_products[i] = right_products[i+1] * nums[i+1] # 合并结果 for i in range(n): answer[i] = left_products[i] * right_products[i] return answer

代码解释

  • 使用三个数组:left_products存储每个元素左侧的累积乘积,right_products存储右侧累积乘积。
  • 先从左向右计算左侧乘积,再从右向左计算右侧乘积。
  • 最后合并结果得到每个位置的乘积。
  • 时间复杂度:$O(n)$,空间复杂度:$O(n)$。

这些题目覆盖了普通数组操作的核心技巧,如双指针、动态规划等。建议您在LeetCode平台上实际练习这些题目,加深理解。如果您有其他具体题目需求,我可以进一步提供帮助!

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

内存指针是什么?为什么指针还要有偏移量?

原文链接&#xff1a;内存指针是什么&#xff1f;为什么指针还要有偏移量&#xff1f; < Ping通途说 1. 什么是内存指针、偏移量&#xff1f; 内存指针是一个存储内存地址的变量&#xff0c;它指向计算机内存中的某个特定位置。可以把它想象成&#xff1a; 现实世界的比喻&a…

作者头像 李华
网站建设 2026/2/27 21:31:03

以太网技术全解:从电缆到云端的通信基石

第一章&#xff1a;网络世界的物理基础与历史演进 1.1 序言&#xff1a;看不见的数字血脉 当我们点击网页上的链接、发送一封电子邮件&#xff0c;或者在视频会议中向同事挥手致意时&#xff0c;我们很少会去思考这些数据是如何在物理世界中穿梭的。我们生活在一个高度互联的…

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

AI工程师的成长指南

AI工程是目前最好的职业机会之一&#xff0c;但我一直看到人们花费数年学习却几乎没有成果。 如果你学习AI工程已经有一段时间了&#xff0c;仍然感觉被困在教程地狱中&#xff0c;我可以告诉你这不是关于努力——而是关于方向。 今天我们要讨论的是那些拖慢你速度的错误&…

作者头像 李华
网站建设 2026/2/27 10:44:03

MCP (Model Context Protocol) 技术理解 - 第一篇

文章目录 引言MCP是什么MCP到底解决什么问题&#xff1f;MCP的架构小结 引言 我一直为网上没有很好且通俗易懂的MCP技术文档而烦恼&#xff0c;所以我通过记录自己查阅官方文档来写一份通俗易懂的MCP技术文档&#xff0c;从架构到实战&#xff0c;既有技术深度&#xff0c;又能…

作者头像 李华
网站建设 2026/2/28 22:20:57

向阳花木(二)C++ ATTR 宏自动属性生成器——封装配置项

C 宏封装配置项&#xff08;多属性接口&#xff09;1. 背景2. ATTR 宏的定义2.1 ATTR.h2.2 ATTR 实际生成的代码2.3 最小示例3. ATTR 使用示例3.1 ATTR 的基本使用规则3.2 读取属性&#xff08;Getter&#xff09;3.3 属性赋值&#xff08;Setter&#xff09;3.4 常见错误总结1…

作者头像 李华
网站建设 2026/3/1 2:49:13

科技修仙(1)Excel入门训练学习算法——东方仙盟

核心代码核心算法// ************************** 修仙版题目配置&#xff08;含公式答案&#xff09; ************************** const xianQuestion {"title": "练气期第1关&#xff1a;学生总分悟道","rows": 6, // 作答行数"lingqiPe…

作者头像 李华