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

专业网站建设技术也是网络品牌建设和推广的基础

专业网站建设技术,也是网络品牌建设和推广的基础,专业做网站官网,网站建设及照片使用保密协议目标和 题目 给一个都是正整数的组合,然后你可以在里面任意添加或-,求使得最后结果为 目标和S(target)的有多少种方法? 范围 数组非空,且长度不会超过 20 。初始的数组的和不会超过 1000 。保证返回的…

目标和

题目

给一个都是正整数的组合,然后你可以在里面任意添加+或-,求使得最后结果为

目标和S(target)的有多少种方法?

范围

  • 数组非空,且长度不会超过 20 。
  • 初始的数组的和不会超过 1000 。
  • 保证返回的最终结果能被 32 位整数存下。

思路

用背包方法的话,这是怎么带入背包方法的?任意添加+或-后会分成两个组合

+是left(总和),-是right(总和),如果结果为目标和target的话,sum=left+right(总和),target=left-right(目标和),推出right=left-target 推出sum=left+(left-target)最后推出 left=(target+sum)/2,利用target和sum都确定这一点,可以求出+的组合left来。

带入背包问题

假设加法的总和为x(left),那么减法对应的总和就是sum - x。

所以我们要求的是 x - (sum - x) = target

x = (target + sum) / 2

此时问题就转化为,装满容量为x的背包,有几种方法。

这个时候装满了容量为x的背包相当于,任意+或者-之后的目标值被满足了。

这里如果x = (target + sum) / 2没有被整除,说明最后目标值不能为target,说明没有方案

同时如果 S的绝对值大于sum,那么也没有方案

递推公式

dp[j] += dp[j - nums[i]]

dp[j] 表示:填满j(包括j)这么大容积的包,有dp[j]种方法,nums[i]是那个都是正整数的组合的第i个数,方法不同的方法就不考虑放还是不放了,都放进去,然后累加起来。比如

  • 已经有一个1(nums[i]) 的话,有 dp[4]种方法 凑成 容量为5的背包。
  • 已经有一个2(nums[i]) 的话,有 dp[3]种方法 凑成 容量为5的背包。
  • 已经有一个3(nums[i]) 的话,有 dp[2]中方法 凑成 容量为5的背包
  • 已经有一个4(nums[i]) 的话,有 dp[1]中方法 凑成 容量为5的背包
  • 已经有一个5 (nums[i])的话,有 dp[0]中方法 凑成 容量为5的背包
  • 他们的dp[1-5]种方法都加起来。

初始化

dp[0]=1,为什么?不知道,按定义来,容量为0的背包的最大方法数为1,+0和-0是一种方法吗?总之dp[0]=1能通过

总代码

class Solution {
public:int findTargetSumWays(vector<int>& nums, int S) {int sum = 0;for (int i = 0; i < nums.size(); i++) sum += nums[i];if (abs(S) > sum) return 0; // 此时没有方案if ((S + sum) % 2 == 1) return 0; // 此时没有方案int bagSize = (S + sum) / 2;vector<int> dp(bagSize + 1, 0);dp[0] = 1;for (int i = 0; i < nums.size(); i++) {for (int j = bagSize; j >= nums[i]; j--) {dp[j] += dp[j - nums[i]];}}return dp[bagSize];}
};

这题也挺抽象的

一和零

题目

给一个元素只由0和1组成的集合strs,再给两个正整数m和n,要求找出最多有m个0和n个1的集合strs的子集,同时这个子集的元素最多。

示例 :

  • 输入:strs = ["10", "0", "1"], m = 1, n = 1
  • 输出:2
  • 解释:最大的子集是 {"0", "1"} ,所以答案是 2 。

思路

带入背包问题,相当于把strs的每个元素作为物品,每个物品计算他们的0和1的数量,然后执行放和不放最多承载m个0和n个1背包的操作,区别不过这里有0,1两个维度而已。

m 和 n 和 元素最多的子集 是3个维度,用二维数组dp[i][j],意思是最多m个0和n个1的集合的最大元素个数是dp[i][j],然后套用01背包公式求出结果就行了。

递推公式

dp[i][j] = max(dp[i][j], dp[i - zeroNum][j - oneNum] + 1);

由01背包的递推公式:dp[j] = max(dp[j], dp[j - weight[i]] + value[i])得来,

zeroNum oneNum相当于之前的重量weight[i],dp[i][j]和dp[i - zeroNum][j - oneNum]的意思还是放入还是不放入的意思,不过由之前只有 j 的一个维度变成了 i 和 j 的两个维度,加1是相当于之前的价值value[i],因为每次遍历的是单个字符串,所以只能+1.

初始化

物品价值不会为负数,初始化为0

vector<vector<int>> dp(m + 1, vector<int> (n + 1, 0));

遍历顺序

一维度的01背包都是后续遍历,这里虽然像两维度的,但却是两个相同维度的一维度,所以顺序先遍历那边都行,我是这样理解的。

总代码

class Solution {
public:int findMaxForm(vector<string>& strs, int m, int n) {vector<vector<int>> dp(m + 1, vector<int> (n + 1, 0)); // 默认初始化0for (string str : strs) { // 遍历每个物品,也就是每个字符串int oneNum = 0, zeroNum = 0;for (char c : str) {//遍历当前物品也就是当前的字符串的0和1数量if (c == '0') zeroNum++;else oneNum++;}//用上面得到当前字符串的0和1数量for (int i = m; i >= zeroNum; i--) { // 遍历背包容量且从后向前遍历!for (int j = n; j >= oneNum; j--) {dp[i][j] = max(dp[i][j], dp[i - zeroNum][j - oneNum] + 1);}}}//注意第一个for到这里才结束return dp[m][n];}
};

这题也蛮抽象的

http://www.yayakq.cn/news/176516/

相关文章:

  • 二元期权网站建设和网站建设签合同
  • 网站免费建立WordPress制作404页面
  • ps网站子页怎么做的网站百度指数分析
  • 慕课网站开发和网站合作有哪些活动可以做
  • 长治招聘网站建设wordpress的菜单静态
  • 山西运城给网站做系统的公司西安seo公司哪家好
  • 建设小辣猫的网站wordpress印刷模版
  • html5 网站 代码上海建设网站公
  • 做网站流量钱谁给湖州网站建设公司哪家好
  • 写作网站打不开怎样看一个网站的浏览量
  • 仿历史网站模板做网站开发学什么
  • 自己做的网站怎么传到服务器网络营销实务教案
  • 做那个的网站谁有dede中英文企业网站
  • 网站开发工程师绩效考核表应用公园收费标准
  • 淄博网站文章优化小红书网页版
  • 呼伦贝尔网站建设iis7配置多个网站
  • 中国建设服务信息网站北京装修公司电话名单
  • 四川建设公司网站html5 触屏网站 案例
  • 网站建设同行抄袭阜阳手机端网站建设
  • 学做档案类网站大连企业网站建设公司
  • 阿里云电影网站建设教程网络开发
  • 网站建设属于商标哪个类上海国际物流网站建设
  • 网络营销推广公司网站杨和网站设计
  • 网站做快捷方式wordpress过滤敏感
  • 佛山营销网站建设南昌招商网站建设
  • 网站模板制作教程番禺做网站的
  • 做个英文网站产品通过网站做营销
  • 官方网站建设需要哪个部门审批做dj网站用什么建站系统比较好
  • 嘉兴网站制作多少钱淘宝运营培训机构排名
  • 网站和微信同步建设网络策划人