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

怎么自己做微网站外贸公司如何做推广

怎么自己做微网站,外贸公司如何做推广,网站建设 推广,外贸一般在哪个网站做的文章目录 1. 暴力求解2. 差分数组二分查找leedcodet评论题解 leetcode:3356. 零数组变换② 给你一个长度为 n 的整数数组 nums 和一个二维数组 queries,其中 queries[i] [li, ri, vali]。 每个 queries[i] 表示在 nums 上执行以下操作: 将…

文章目录

      • 1. 暴力求解
      • 2. 差分数组+二分查找
        • leedcodet评论题解

leetcode:3356. 零数组变换②

给你一个长度为 n 的整数数组 nums 和一个二维数组 queries,其中 queries[i] = [li, ri, vali]

每个 queries[i] 表示在 nums 上执行以下操作:

  • nums[li, ri] 范围内的每个下标对应元素的值 最多 减少 vali
  • 每个下标的减少的数值可以独立选择。

零数组 是指所有元素都等于 0 的数组。

返回 k 可以取到的 最小非负 值,使得在 顺序 处理前 k 个查询后,nums 变成 零数组。如果不存在这样的 k,则返回 -1。

示例 1:

输入: nums = [2,0,2], queries = [[0,2,1],[0,2,1],[1,1,3]]

输出: 2

解释

  • 对于 i = 0(l = 0, r = 2, val = 1):
    • 在下标 [0, 1, 2] 处分别减少 [1, 0, 1]。
    • 数组将变为 [1, 0, 1]。
  • 对于 i = 1(l = 0, r = 2, val = 1):
    • 在下标 [0, 1, 2] 处分别减少 [1, 0, 1]。
    • 数组将变为 [0, 0, 0],这是一个零数组。因此,k 的最小值为 2。

示例 2:

输入: nums = [4,3,2,1], queries = [[1,3,2],[0,2,1]]

输出: -1

解释

  • 对于 i = 0(l = 1, r = 3, val = 2):
    • 在下标 [1, 2, 3] 处分别减少 [2, 2, 1]。
    • 数组将变为 [4, 1, 0, 0]。
  • 对于 i = 1(l = 0, r = 2, val = 1):
    • 在下标 [0, 1, 2] 处分别减少 [1, 1, 0]。
    • 数组将变为 [3, 0, 0, 0],这不是一个零数组。

1. 暴力求解

暴力求解:倒在621/627

class Solution(object):def minZeroArray(self, nums, queries):""":type nums: List[int]:type queries: List[List[int]]:rtype: int"""# 暴力求解arr = [1] * len(nums)sum0 = 0for num in nums:sum0 += numif sum0 == 0:return 0for epoch, (l, r, val) in enumerate(queries):for i in range(l, r + 1):# 通过数组arr,如果减到0,则之后不用下面的操作if arr[i]:if nums[i] > val:nums[i] -= valelse:nums[i] = 0 arr[i] = 0sum = 0for num in nums:sum += numif sum == 0:return epoch + 1return -1

2. 差分数组+二分查找

class Solution(object):def minZeroArray(self, nums, queries):""":type nums: List[int]:type queries: List[List[int]]:rtype: int"""# 差分数组+二分查找def check(k):diff = [0] * (len(nums) + 1)for l, r, val in queries[:k]:diff[l] += valdiff[r + 1] -= valsum_i = 0for i in range(len(nums)):sum_i += diff[i]if nums[i] > sum_i:return Falsereturn Trueleft = -1right = len(queries) + 1while left + 1 < right:mid = (left + right) // 2# 看中间mid是否满足条件使得零数组if check(mid):right = midelse:left = midreturn right if right <= len(queries) else -1
leedcodet评论题解

在这里插入图片描述
复杂度分析
时间复杂度:O((n+q)logq),其中 n 是 nums 的长度,q 是 queries 的长度。
空间复杂度:O(n)。Python 忽略切片空间。

链接:https://leetcode.cn/problems/zero-array-transformation-ii/solutions/2991505/liang-chong-fang-fa-er-fen-da-an-chai-fe-rcvg/
来源:力扣(LeetCode)

http://www.dtcms.com/wzjs/422446.html

相关文章:

  • 1网站建设整合营销网络推广
  • wordpress改固定连接搜索引擎优化的方式有哪些
  • 网站互联网接入商优化网站
  • 网站制作视频教程大全无锡百度推广开户
  • 网站首页做301排名轻松seo 网站推广
  • 昆山网站建设 技术支持 力得网络宁波seo排名方案优化公司
  • 贵阳专业做网站网站如何推广营销
  • 深圳自适应网站开发公司网站推广多少钱
  • 广州做网站怎么样网店推广的渠道有哪些
  • 网站做的和别人一样违法怎么做游戏推广员
  • 怎么查看网站解析网络代运营推广
  • 网站越来越难做扬州seo推广
  • 浙江建设信息港网站考试成绩查询免费建立网站步骤
  • wordpress自定义文章类型输出数量百度智能小程序怎么优化排名
  • 贵美商城网站的首页怎么做代码百度企业号
  • wordpress后台插件的关闭宁波seo优化服务
  • 用QQ群做网站排名百度电脑网页版入口
  • 山东省和住房建设厅网站首页平面设计正规培训机构
  • 哪有做婚介网站的微信引流推广精准粉
  • 网站推广计划至少应包括中国企业网官方网站
  • 做交友网站赚钱吗seo的收费标准
  • b2b电商资源网站排名优化seo
  • 网站开发时做推广的公司一般都叫什么
  • aspcms手机网站优秀营销软文范例800字
  • 做网站ui百度竞价推广开户内容
  • 哪个网站有适合小学生做的题指数基金定投技巧
  • 浑南区建设局网站今天重大国际新闻
  • 河北专业网站建设公司推荐深圳google推广
  • 做移动端网站软件下载学开网店哪个培训机构好正规
  • 西安网络推广网站优化百度云官网登录首页