当前位置: 首页 > news >正文

商业网站建设知识点湖北百度推广电话

商业网站建设知识点,湖北百度推广电话,太原整站优化,php做网站很快嘛#左耳听风 ARST 打卡活动重启# 目录 一、题目 二、解题方法一 三、解题方法二 关于 ARTS 的释义 —— 每周完成一个 ARTS: ● Algorithm: 每周至少做一个 LeetCode 的算法题 ● Review: 阅读并点评至少一篇英文技术文章 ● Tips: 学习至少一个技术技巧 ● Share:…

#左耳听风 ARST 打卡活动重启#

目录

 一、题目

二、解题方法一

三、解题方法二


 关于 ARTS 的释义 —— 每周完成一个 ARTS:
● Algorithm: 每周至少做一个 LeetCode 的算法题
● Review: 阅读并点评至少一篇英文技术文章
● Tips: 学习至少一个技术技巧
● Share: 分享一篇有观点和思考的技术文章

希望通过此次活动能聚集一波热爱技术的人,延续好奇、探索、实践、分享的精神。
 


 一、题目

给你一个长度为 n 的整数数组 nums ,请你判断在 最多 改变 1 个元素的情况下,该数组能否变成一个非递减数列。

我们是这样定义一个非递减数列的: 对于数组中任意的 i (0 <= i <= n-2),总满足 nums[i] <= nums[i + 1]。

示例 1:

输入: nums = [4,2,3]
输出: true
解释: 你可以通过把第一个 4 变成 1 来使得它成为一个非递减数列。


示例 2:

输入: nums = [4,2,1]
输出: false
解释: 你不能在只改变一个元素的情况下将其变为非递减数列。

二、解题方法一

def checkPossibility(nums):for i in range(len(nums) - 1):if nums[i] > nums[i + 1]:# 如果当前元素比下一个元素大,则需要将当前元素减小或将下一个元素增大# 为了只改变一个元素,我们可以将当前元素减小到比下一个元素小的最小值# 或者将下一个元素增大到比当前元素大的最小值# 因此,我们只需要找到这两个数中的最小值即可return min(nums[i], nums[i + 1]) < max(nums[i], nums[i + 1])# 如果所有元素都满足非递减的条件,则返回 Truereturn True

这段代码实现了一个函数 `checkPossibility`,用于判断在最多改变 1 个元素的情况下,给定的整数数组是否能变成一个非递减数列。

函数的输入参数为一个整数数组 `nums`。

首先,我们使用一个循环遍历数组中的每个元素 `i`,并检查当前元素 `nums[i]` 是否比下一个元素 `nums[i + 1]` 大。如果是,则说明当前元素需要被修改,以使得整个数组能够变成非递减数列。

为了只改变一个元素,我们可以将当前元素 `nums[i]` 减小到比下一个元素 `nums[i + 1]` 小的最小值,或者将下一个元素 `nums[i + 1]` 增大到比当前元素 `nums[i]` 大的最小值。因此,我们只需要找到这两个数中的最小值即可。

具体来说,我们可以使用 Python 内置函数 `min()` 来找到两个数中的最小值。如果这个最小值小于等于另一个数,则说明它们可以相等,即不需要进行任何操作;否则,我们需要将较小的那个数减小到等于较大的那个数。

最后,如果所有元素都满足非递减的条件,则返回 True;否则,返回 False。

三、解题方法二

另一种解决方法是使用双指针法。具体来说,我们可以定义两个指针 `left` 和 `right`,分别指向数组的开头和结尾。然后,我们从左到右遍历数组中的每个元素,并检查当前元素是否小于等于右边的元素。如果是,则说明当前元素需要被修改,以使得整个数组能够变成非递减数列。

为了只改变一个元素,我们可以将当前元素 `nums[i]` 减小到比右边的元素 `nums[j]` 小的最小值,或者将右边的元素 `nums[j]` 增大到比当前元素 `nums[i]` 大的最小值。因此,我们只需要找到这两个数中的最小值即可。

具体来说,我们可以使用双指针法来实现这个算法。首先,我们将 `left` 指针指向数组的第一个元素,将 `right` 指针指向数组的最后一个元素。然后,我们从左到右遍历数组中的每个元素 `i`,并检查当前元素是否小于等于右边的元素 `nums[j]`。如果是,则说明当前元素需要被修改,我们需要移动 `left` 指针到下一个位置,并更新左边的最小值;否则,我们需要移动 `right` 指针到前一个位置,并更新右边的最小值。最后,如果所有元素都满足非递减的条件,则返回 True;否则,返回 False。

这个算法的时间复杂度为 O(n),其中 n 为数组的长度。

def checkPossibility(nums):left, right = 0, len(nums) - 1for i in range(len(nums)):while left < right and nums[left] > nums[i]:# 如果左边的元素比当前元素大,则将左边的指针向右移动一位left += 1while left < right and nums[right] < nums[i]:# 如果右边的元素比当前元素小,则将右边的指针向左移动一位right -= 1if left >= right:# 如果左边的指针已经到达了数组的末尾,说明无法通过修改元素使得整个数组变成非递减数列return False# 将当前元素修改为左边和右边中的最小值,以满足非递减的条件nums[i] = min(nums[left], nums[right])return True

http://www.tj-hxxt.cn/news/111946.html

相关文章:

  • wordpress 信息字段seo独立站
  • 怎么再各网站上做宣传百度开户代理商
  • 深圳哪个做网站好优化网站建设开发
  • 做的网站如何发更新关键词seo排名怎么样
  • 微网站建设方案书seo排名点击 seo查询
  • 家装效果图网站seo诊断优化方案
  • 使用angularjs的网站霸屏推广
  • 平面设计师灵感网站冯耀宗seo视频教程
  • 公司形象墙设计效果图大全360优化大师官方最新
  • 专做视频和ppt的网站网站模板哪家好
  • 切实加强门户网站建设希爱力副作用太强了
  • 做订阅号要建立网站吗合肥推广外包公司
  • 四川住房建设网站海外建站
  • 沧州网站建设刘磊产品品牌策划方案
  • 南京网站高端湖南靠谱seo优化公司
  • 网站脑图用什么做网络营销有什么特点
  • 旅游网站网页设计图片企业培训机构排名前十
  • 网站设计搜索栏怎么做个人网站设计
  • 无锡上网站建设公司网站搭建
  • 公司网站搭建费用广告主平台
  • 影响网站排名的因素 权重百度开户流程
  • 网站模版修改好用的搜索引擎有哪些
  • 自己做网站怎么赚钱网络营销型网站
  • 建设微信商城网站的公司如何解决网站只收录首页的一些办法
  • 长春专业做网站公司真正免费建站网站
  • 网页与制作seo引擎优化方案
  • 怎么做网站移动端百度广告位价格
  • 南京哪个网站做物业贷aso优化工具
  • 企业多语言网站开发泾县网站seo优化排名
  • 淘宝网站可以做百度快照吗网站seo外包公司