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

网站论坛制作seo是搜索引擎营销

网站论坛制作,seo是搜索引擎营销,灯具电商网站建设方案,wordpress 焦点图大小494. 目标和 - 力扣(LeetCode) 这个代码是用来解决“目标和”问题的,即在给定一个非负整数数组 nums 和一个整数 target 的情况下,通过在每个数字前添加 或 - 号,使得整个表达式的和等于 target,求有多少…

494. 目标和 - 力扣(LeetCode)

这个代码是用来解决“目标和”问题的,即在给定一个非负整数数组 nums 和一个整数 target 的情况下,通过在每个数字前添加 + 或 - 号,使得整个表达式的和等于 target,求有多少种不同的方法。

方法思路

  1. 问题转换​:首先,我们需要将问题转换为一个背包问题。假设所有添加 + 的数字之和为 pos,所有添加 - 的数字之和为 neg。那么有:

    • pos - neg = target
    • pos + neg = sum(nums)
      通过这两个等式,可以推导出 pos = (sum(nums) + target) / 2。因此,问题转化为在 nums 中找到若干数字,使其和为 pos,即一个典型的背包问题。
  2. 边界条件处理​:

    • 如果 sum(nums) < abs(target),那么无论如何组合都无法达到 target,直接返回 0。
    • 如果 (sum(nums) + target) 不是偶数,那么 pos 不是整数,同样无法达到,返回 0。
  3. 动态规划(记忆化搜索)​​:使用深度优先搜索(DFS)结合记忆化来避免重复计算。dfs(i, c) 表示从前 i 个数字中选出若干数字,使其和为 c 的方法数。递归关系如下:

    • 如果当前数字 nums[i] 大于剩余容量 c,则只能不选该数字,即 dfs(i-1, c)
    • 否则,可以选择不选或选该数字,即 dfs(i-1, c) + dfs(i-1, c - nums[i])
class Solution:def findTargetSumWays(self, nums: List[int], target: int) -> int:# p->+# q->-# p+q = s# p-q = target# p = (s-target)/2 # p必须是整数,s必须大于targets = sum(nums) - abs(target)if s<0 or s%2 == 1:return 0m = s//2memo = {}# i 是当前处理的数字在 nums 数组中的索引# c 是当前剩余的目标和​(即背包问题中的剩余容量)def dfs(i,c):if(i,c) in memo:return memo[(i,c)]# 当 i 变为负数时,表示所有数字已经处理完毕。if i < 0:return 1 if c==0 else 0# 如果当前数字 nums[i] 比剩余目标和 c 还大,那么不能选它,只能跳过(即 dfs(i - 1, c))if c < nums[i]:memo[(i,c)] = dfs(i-1,c)# 如果 nums[i] 可以选(即 c >= nums[i]),则有两种选择:# ​不选 nums[i]​:继续递归 dfs(i - 1, c)。# ​选 nums[i]​:递归 dfs(i - 1, c - nums[i]),并减少剩余目标和 celse:memo[(i,c)] = dfs(i-1,c) +dfs(i-1,c-nums[i])return memo[(i,c)]# i = len(nums) - 1 表示从数组的最后一个数字开始处理return dfs(len(nums)-1,m)# 从最后一个数字开始处理(i = len(nums) - 1)是更自然的选择,因为:# ​终止条件更清晰​(i < 0)。# ​更符合动态规划填表顺序​(从后往前依赖)。# ​记忆化存储更方便​((i, c) 对更易管理)。# ​与数学归纳法一致​(假设 i 之后的问题已解决)。# ​代码更简洁​(减少边界判断)。

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

相关文章:

  • 做网站建设公司五种网络营销推广方法
  • 自助建站网站哪个好上海网络优化seo
  • 短视频推广的好处青岛seo霸屏
  • 网站建设优化服务方案模板厦门人才网官方网站
  • 小米14系列发布会微博手机影像年班级优化大师简介
  • 房产手机网站开发下载一个百度时事新闻
  • 北京做企业网站的公司培训师资格证怎么考
  • 建网站申请长沙网站se0推广优化公司
  • 上海网站建设公司怎么样百度广告怎么投放多少钱
  • 宣城网站 建设深圳百度推广客服电话多少
  • 珠宝网站建设方案谷歌是如何运营的
  • 佛山网页网站设计外包网站有哪些
  • 网站建设代理加盟苏州百度代理公司
  • 网站qq联系怎么做百度网站如何优化排名
  • 长宁区网站建设网站制作线上推广策划方案范文
  • 潜山云建站网站建设百度网站打开
  • 广告制作服务上海搜索seo
  • 网站套程序夸克搜索入口
  • 互联网营销 网站 推荐汕头网页搜索排名提升
  • wordpress 网站开发湖南seo优化排名
  • 人大网站建设情况介绍重庆网络推广
  • 做网站里面的内容佛山网站seo
  • 自动化设计网站建设岳阳网站设计
  • 域名通过了才可以做网站吗百度大搜数据多少钱一条
  • 做黄页网站要告我滴滴友链
  • 深圳网站设计灵点网络公司不错电子商务主要学什么内容
  • 网站版建设seo标题生成器
  • 湖北长城建设实业有限公司网站网站模板搭建
  • 注册网站代码全网营销是什么意思
  • 网站页脚信息seo关键词找29火星软件