力扣刷题之旅:进阶篇(一)

         力扣(LeetCode)是一个在线编程平台,主要用于帮助程序员提升算法和数据结构方面的能力。以下是一些力扣上的入门题目,以及它们的解题代码。 

--点击进入刷题地址 


题目1:三数之和

题目描述:

        给定一个包含n个整数的数组nums,判断nums中是否存在三个元素a,b,c ,使得a + b + c = 0 ?找出所有满足条件且不重复的三元组。

代码实现:

def threeSum(nums):  
    res = []  
    n = len(nums)  
    for i in range(n-2):  
        if i > 0 and nums[i] == nums[i-1]:  
            continue  
        left = i + 1  
        right = n - 1  
        while left < right:  
            total = nums[i] + nums[left] + nums[right]  
            if total == 0:  
                res.append([nums[i], nums[left], nums[right]])  
                while left < right and nums[left] == nums[left+1]:  
                    left += 1  
                while left < right and nums[right] == nums[right-1]:  
                    right -= 1  
                left += 1  
                right -= 1  
            elif total < 0:  
                left += 1  
            else:  
                right -= 1  
    return res

解题思路:

  •         这个问题是一个经典的数组问题,要求在给定的整数数组中找到所有和为特定目标值的三元组。我们需要遍历数组中的所有可能的三元组,并检查它们的和是否等于目标值。
  •         由于题目要求返回所有不重复的三元组,我们需要使用一个集合来存储已经找到的三元组,以便在找到重复的三元组时将其跳过。在遍历数组时,我们可以使用两个指针i和j来分别指向数组中的第一个和第二个数,然后使用第三个指针k从数组的末尾向前遍历。这样我们可以保证每次找到的三元组的第一个数都不相同,从而避免了重复。
  •         在找到一个和为目标值的三元组后,我们可以将其添加到结果数组中,并继续遍历数组,直到找到所有的三元组为止。
  •         需要注意的是,为了避免重复的三元组,我们需要跳过重复的元素。具体来说,当i和j指向的元素相同时,我们需要跳过它们,继续遍历数组。
  • 最后,我们返回结果数组即可。

题目2:三数之和 II

题目描述: 

        给定一个包含n个整数的数组nums,其中每个元素的值介于1到1000之间。找出nums中同时满足下列三个条件的所有三个整数num1、num2和num3:num1 + num2 + num3 = target,num1 < num2 < num3,num1、num2、num3均不相同。返回所有不重复的三元组。要求时间复杂度为O(n^2)。

解题思路:

        这个问题可以使用三重循环遍历数组来解决。首先,我们定义三个指针i、j和k,分别指向数组中的起始位置、第二个数和第三个数。然后,我们使用三重循环遍历数组中的所有可能的三元组,并检查是否满足条件具体来说,我们检查i、j和k指向的三个数是否满足条件,如果满足条件则将它们作为一个三元组添加到结果中最后返回所有不重复的三元组即可。

代码实现:

def threeSum(nums, target):  
    res = []  
    n = len(nums)  
    for i in range(n):  
        for j in range(i+1, n):  
            for k in range(j+1, n):  
                if nums[i] + nums[j] + nums[k] == target and nums[i] != nums[j] != nums[k]:  
                    res.append([nums[i], nums[j], nums[k]])  
    return res

题目3:矩阵中的路径

        给定一个二维矩阵,其中0表示空地,1表示障碍物。从左上角开始,要走到右下角只能向右或向下走,问从左上角走到右下角有多少种不同的路径?

解题思路:

这个问题可以使用动态规划来解决。我们可以定义一个二维数组dp,其中dp[i][j]表示从左上角走到位置(i, j)的路径数。对于位置(0, 0),它只有一种路径,即dp[0][0] = 1。对于其他位置,如果它没有被障碍物阻挡,则可以从上方或左方走到该位置,即dp[i][j] = dp[i-1][j] + dp[i][j-1]。如果它被障碍物阻挡,则无法从上方或左方走到该位置,即dp[i][j] = 0。最后返回dp[n-1][m-1],其中n和m分别为矩阵的行数和列数。

代码实现:

def uniquePaths(matrix):  
    if not matrix:  
        return 0  
    n, m = len(matrix), len(matrix[0])  
    dp = [[0] * m for _ in range(n)]  
    dp[0][0] = 1  
    for i in range(n):  
        for j in range(m):  
            if matrix[i][j] == 1:  
                continue  
            if i > 0:  
                dp[i][j] += dp[i-1][j]  
            if j > 0:  
                dp[i][j] += dp[i][j-1]  
            dp[i][j] -= dp[i-1][j-1] if i > 0 and j > 0 else 0  
    return dp[n-1][m-1]

 

题目4:旋转图像

给定一个m x n的矩阵matrix,将其旋转90度并返回结果。旋转后的矩阵应该是一个n x m的矩阵。

解题思路:

这个问题可以使用分治法来解决。我们可以将矩阵分成四个部分:左上角、右上角、右下角和左下角。首先,我们分别对左上角和右上角、左下角和右下角进行旋转操作。然后,我们将左上角和右上角、左下角和右下角的结果合并在一起,得到最终的旋转后的矩阵。具体步骤如下:

  1. 对左上角和右上角进行旋转操作:将左上角的m x m矩阵旋转90度,得到一个m x m的矩阵。同时,将右上角的(n-m) x (n-m)矩阵旋转90度,得到一个(n-m) x (n-m)的矩阵。这样,左上角和右上角的区域就得到了旋转后的结果。
  2. 对左下角和右下角进行旋转操作:将左下角区域的(m-n) x m矩阵旋转90度,得到一个m x (m-n)的矩阵。同时,将右下角的(n-m) x (n-m)矩阵旋转90度,得到一个(n-m) x (n-m)的矩阵。这样,左下角和右下角的区域就得到了旋转后的结果。
  3. 将左上角和右上角、左下角和右下角的区域合并在一起,得到最终的旋转后的矩阵。
def rotateImage(matrix):  
    n = len(matrix)  
    # 遍历每个元素,将其与对应的对称位置的值进行交换  
    for i in range(n):  
        for j in range(i+1, n):  
            matrix[i][j], matrix[j][i] = matrix[j][i], matrix[i][j]  
    return matrix

 

题目5:最长递增子序列II

给定一个未排序的整数数组nums,找到最长递增子序列的长度。要求时间复杂度为O(nlogn),且空间复杂度为O(1)。

解题思路:

这个问题可以使用动态规划结合单调栈来解决。首先,我们可以使用单调栈来找到每个元素前面比它小的元素的位置。具体来说,我们可以使用一个栈来维护数组中的元素,遍历数组时,如果当前元素大于栈顶元素,则将栈顶元素弹出,直到找到一个小于等于当前元素的元素或者栈为空为止。然后,我们遍历数组中的每个元素,对于每个元素,我们找到它前面比它小的元素的位置,并更新dp数组。最后返回dp数组中的最大值即可。

代码实现:

def lengthOfLIS(nums):  
    n = len(nums)  
    if n == 0:  
        return 0  
    dp = [1] * n  
    stack = []  
    for i in range(n):  
        while stack and nums[i] > nums[stack[-1]]:  
            stack.pop()  
        if not stack:  
            dp[i] = 1  
        else:  
            dp[i] = dp[stack[-1]] + 1  
        stack.append(i)  
    return max(dp)

 

题目6:最大子序和

给定一个整数数组nums,求数组中连续子序列的最大和。要求使用Kadane算法,时间复杂度为O(n)。

解题思路:

这个问题可以使用Kadane算法来解决。Kadane算法的核心思想是维护一个当前的最大子序列和,初始时为0。遍历数组中的每个元素,如果当前元素大于0,则将其加入到当前最大子序列和中,否则将其与当前最大子序列和相减。最后返回最大子序列和即可。

代码实现:

def maxSubArray(nums):  
    if not nums:  
        return 0  
    max_sum = nums[0]  
    current_sum = nums[0]  
    for i in range(1, len(nums)):  
        if nums[i] > 0:  
            current_sum += nums[i]  
        else:  
            current_sum = nums[i]  
        max_sum = max(max_sum, current_sum)  
    return max_sum

        这些题目属于中等难度的算法题,主要涉及矩阵操作、路径寻找、子序列和的最大值、三数之和的条件求解等方面的知识和技巧。解题过程中需要运用循环、递归、动态规划等算法和数据结构,以及一些数学推理和逻辑分析的方法。通过解决这些题目,可以提高编程能力和算法设计水平,加深对数据结构和算法的理解和应用。 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

算法学习——LeetCode力扣哈希表篇1

算法学习——LeetCode力扣哈希表篇1 242. 有效的字母异位词 242. 有效的字母异位词 - 力扣&#xff08;LeetCode&#xff09; 描述 给定两个字符串 s 和 t &#xff0c;编写一个函数来判断 t 是否是 s 的字母异位词。 注意&#xff1a;若 s 和 t 中每个字符出现的次数都相同…

轻松修复msvcr100.dll丢失的解决方法,修复时需要注意事项

msvcr100.dll文件缺失是一种普遍遇到的电脑问题&#xff0c;此类问题会妨碍一些程序的正常启动或引发其他错误。幸运的是&#xff0c;我们可以采取多种方法修复msvcr100.dll文件。下面将介绍三种常用的解决方法&#xff0c;包括更新电脑系统、使用dll修复工具修复以及手动下载m…

docker安全与https协议

一、docker存在的安全问题 1、docker 自身漏洞 docker 应用本身实现上会有代码缺陷&#xff0c;docker 历史版本共有超过 20 项漏洞 2、docker公有仓库安全问题 docker 提供了 docker hub&#xff0c;可以让用户上传创建的镜像&#xff0c;以便其他用户下载&#xff0c;快速…

Linux内核编译-ARM

步骤一、下载源码及交叉编译器后解压 linux kernel官网 ARM GCC交叉编译器 步骤二、安装软件 sudo apt-get install ncurses-dev sudo apt-get install flex sudo apt-get install bison sudo apt install libgtk2.0-dev libglib2.0-dev libglade2-dev sudo apt install libs…

【Java篇】——浅拷贝or深拷贝

目录 &#x1f6a9;克隆步骤 &#x1f6a9;拷贝 &#x1f388;浅拷贝 &#x1f388;深拷贝 &#x1f6a9;源代码 &#x1f6a9;克隆步骤 Java 中内置了一些很有用的接口 , Clonable 就是其中之一 .【一般接口都是able来设定的&#xff0c;able是可以..的表示一种能力】 …

tab切换

任务描述&#xff1a;鼠标点击不同商品类别标题时切换不同页面 html代码&#xff1a; <div class"tab"><div class"tab-head"><h3>家电</h3><ul><li><a class"active" href"javascript:;"&g…

arcpy高德爬取路况信息数据json转shp

最近工作上遇到爬取的高德路况信息数据需要在地图上展示出来&#xff0c;由于json数据不具备直接可视化的能力&#xff0c;又联想到前两个月学习了一点点arcpy的知识&#xff0c;就花了一些时间去写了个代码&#xff0c;毕竟手动处理要了老命了。 1、json文件解读 json文件显…

编程实例分享,物流车辆调度管理系统软件教程

编程实例分享&#xff0c;物流车辆调度管理系统软件教程 一、前言 以下教程以 佳易王物流车辆调度管理系统软件V16.0为例说明 如上图&#xff0c;左侧为 导航栏&#xff0c;在系统设置里可以设置打印参数 如上图&#xff0c;填写托运方&#xff0c;货物&#xff0c;司机等信…

走进施耐德电气:数字化转型要奉行长期主义

数字化不是新“银弹”&#xff0c;其前身是电子化、信息化&#xff0c;至今已走过几十年的历程。回头来看&#xff0c;在这个人人都谈数字化、家家都在数字化转型的时代&#xff0c;影响数字化真正走深向实的核心因素有哪些&#xff1f; 2024年1月16日&#xff0c;在主题为“如…

c语言--assert断言(详解)

目录 一、断言的概念二、assert断言2.1 代码12.1.1运行结果2.1.2分析 2.2代码22.2.1运行结果2.2.2分析2.3代码32.3.1运行结果及其分析 三、优点四、缺点五、注意 一、断言的概念 assert.h 头⽂件定义了宏 assert() &#xff0c;用于在运行时确保程序符合指定条件&#xff0c;如…

vue基本语法总结大全

vue基本语法 文章目录 vue基本语法基本用法内容渲染指令属性绑定指令使用js表达式事件绑定指令条件渲染指令v-else和v-else-if指令列表渲染指令v-for中的key 组件化开发安装详细讲解 第三方组件1. 组件间的传值2. element-ui介绍3. 组件的使用4. 图标的使用 Axios网络请求1. Ax…

Redis渗透SSRF的利用

Redis是什么&#xff1f; Redis是NoSQL数据库之一&#xff0c;它使用ANSI C编写的开源、包含多种数据结构、支持网络、基于内存、可选持久性的键值对存储数据库。默认端口是&#xff1a;6379 工具安装 下载地址&#xff1a; http://download.redis.io/redis-stable.tar.gz然…

【Redis】字符串原理--简单动态字符串SDS

一.SDS定义 free 属性值为0&#xff0c;标识SDS没有分配任何未使用空间。len 属性值为5&#xff0c;标识SDS保存了一个5字节长度的字符串。buf 属性是一个char类型数组&#xff0c;数组的前5个字节保存了&#xff0c;R e d i s 五个字符&#xff0c;最后一个保存空字符串 \0…

网络原理TCP/IP(5)

文章目录 IP协议IP协议报头地址管理网段划分特殊的IP地址路由选择以太网认识MAC地址对比理解MAC地址和IP地址DNS&#xff08;域名服务器&#xff09; IP协议 IP协议主要完成的工作是两方面&#xff1a; 地址管理&#xff0c;使用一套地址体系&#xff0c;来描述互联网上每个设…

Springboot集成Camunda并完成一条流程实例

&#x1f496;专栏简介 ✔️本专栏将从Camunda(卡蒙达) 7中的关键概念到实现中国式工作流相关功能。 ✔️文章中只包含演示核心代码及测试数据&#xff0c;完整代码可查看作者的开源项目snail-camunda ✔️请给snail-camunda 点颗星吧&#x1f618; &#x1f496;设计流程定…

测试开发体系

软件测试 通过手工或者工具对 “被测对象”进行测试验证实际结果与预期结果之间是否存在差异 软件测试作用 通过测试工作可以发现并修复软件当中存在的缺陷&#xff0c;从而提高用户对产品的使用信心测试可以降低同类型产品开发遇到问题的风险 软件缺陷 软件缺陷被测试工程…

船舶维保管理:Java与SpringBoot的完美结合

✍✍计算机编程指导师 ⭐⭐个人介绍&#xff1a;自己非常喜欢研究技术问题&#xff01;专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目&#xff1a;有源码或者技术上的问题欢迎在评论区一起讨论交流&#xff01; ⚡⚡ Java实战 |…

Linux openKylin(开放麒麟)系统SSH服务安装配置与公网远程连接

文章目录 前言1. 安装SSH服务2. 本地SSH连接测试3. openKylin安装Cpolar4. 配置 SSH公网地址5. 公网远程SSH连接6. 固定SSH公网地址7. SSH固定地址连接8. 结语 前言 openKylin是中国首个基于Linux 的桌面操作系统开发者平台&#xff0c;通过开放操作系统源代码的方式&#xff…

在工业制造方面,如何更好地实现数字化转型?

实现工业制造的数字化转型涉及利用数字技术来增强流程、提高效率并推动创新。以下是工业制造领域更好实现数字化转型的几个关键步骤&#xff1a; 1.定义明确的目标&#xff1a; 清楚地概述您的数字化转型目标。确定需要改进的领域&#xff0c;例如运营效率、产品质量或供应链…

【vue ezuikit-js】5分钟实现萤石视频放大对焦和缩小对焦

实现功能如上图:点击+按钮,实现画面放大并对焦;点击-,实现画面缩小并对焦。 官网上提供了电子放大的控制按钮和接口,但是只是把当前画面进行放大,并没有对焦,画面模糊。 萤石官方还提供了对焦的接口,根据传入的参数不同,可以实现放大对焦和缩小对焦。但是注意此接口是…