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

怎么做投票 网站seo引擎优化方案

怎么做投票 网站,seo引擎优化方案,郑州网站seo厂家,怎么做网站宣传Day30 OK,今日份的打卡!第三十天 以下是今日份的总结最后一块石头的重量 II目标和一和零 以下是今日份的总结 1049 最后一块石头的重量 II 494 目标和 474 一和零 今天的题目难度不低,掌握技巧了就会很简单,尽量还是写一些简洁代…

Day30 OK,今日份的打卡!第三十天

  • 以下是今日份的总结
    • 最后一块石头的重量 II
    • 目标和
    • 一和零

以下是今日份的总结

1049 最后一块石头的重量 II
494 目标和
474 一和零

今天的题目难度不低,掌握技巧了就会很简单,尽量还是写一些简洁代码 ^ _ ^

最后一块石头的重量 II

思路:

1.确定dp数组以及下标的含义
------ dp[j]表示容量(这里说容量更形象,其实就是重量)为j的背包,最多可以背最大重量为dp[j]。
2.确定递推公式
------01背包的递推公式为:dp[j] = max(dp[j], dp[j - weight[i]] + value[i]);
------本题 :dp[j] = max(dp[j], dp[j - stones[i]] + stones[i]);
3.dp数组如何初始化
------因为重量都不会是负数,所以dp[j]都初始化为0就可以了
4.确定遍历顺序
------如果使用一维dp数组,物品遍历的for循环放在外层,遍历背包的for循环放在内层,且内层for循环倒序遍历!
5.举例推导dp数组

值得注意的是

最后dp[target]里是容量为target的背包所能背的最大重量。
在计算target的时候,target = sum / 2 因为是向下取整,所以sum - dp[target] 一定是大于等于dp[target]的。
那么相撞之后剩下的最小石头重量就是 (sum - dp[target]) - dp[target]。

//二维dp数组实现int lastStoneWeightII(vector<int>& stones) {vector<int>dp(15001,0);int sum = 0;//这堆石头的总重量for(int i = 0;i<stones.size();i++) sum += stones[i];int target = sum / 2;//遍历物品for(int i = 0;i < stones.size(); i++){//遍历背包for(int j = target ; j>=stones[i];j--){//不放石头和放石头 中 取最大值 dp[j] = max(dp[j],dp[j - stones[i]]+stones[i]);}       }return sum - dp[target] - dp[target];}

目标和

思路:
既然为target,那么就一定有
left - right = target
left + right = sum
left = (target + sum)/2 。
此时问题就转化为,装满容量为left的背包,有几种方法。

1.确定dp数组以及下标的含义
------ 填满j(包括j)这么大容积的包,有dp[j]种方法
_
2.确定递推公式
------dp[j] += dp[j - nums[i]],没弄明白什么意思,记住就可以了
_
3.dp数组如何初始化
------在初始化的时候dp[0] 一定要初始化为1
_
4.确定遍历顺序
------nums放在外循环,target在内循环,且内循环倒序
_
5.举例推导dp数组

值得注意的是

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

   int findTargetSumWays(vector<int>& nums, int target) {int sum = 0;for(int i = 0; i < nums.size();i++){sum += nums[i];}//没有方案if((target+sum)%2==1||abs(target)>sum)return 0;int bagSize = (target + 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] + dp[j-nums[i]];//求组合类问题的公式,都是类似这种}}return dp[bagSize];}

一和零

思路:
本题中strs 数组里的元素就是物品,每个物品都是一个!
而m 和 n相当于是一个背包,两个维度的背包

1.确定dp数组以及下标的含义
------ dp[i][j]:最多有i个0和j个1的strs的最大子集的大小为dp[i][j]。
2.确定递推公式
------01背包的递推公式为:dp[j] = max(dp[j], dp[j - weight[i]] + value[i]);
------本题,strs里的字符串有x个0,y个1。
------所以递推公式:dp[i][j] = max(dp[i][j], dp[i - x][j - y] + 1);
------字符串的x和y相当于物品的重量(weight[i]),字符串本身的个数相当于物品的价值(value[i])
3.dp数组如何初始化
------01背包的dp数组初始化为0就可以。
------因为物品价值不会是负数,初始为0,保证递推的时候dp[i][j]不会被初始值覆盖。
4.确定遍历顺序
------一定是外层for循环遍历物品,内层for循环遍历背包容量且从后向前遍历!
5.举例推导dp数组

值得注意的是

这就是一个典型的01背包! 只不过物品的重量有了两个维度而已。

    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 x = 0, y = 0;for (char a : str) {if (a == '0')//统计当前string的‘0’的个数x++;if (a == '1')//统计当前string的‘1’的个数y++;}for (int i = m; i >= x; i--) {for (int j = n; j >= y; j--) {dp[i][j] = max(dp[i][j], dp[i - x][j - y] + 1);}}}return dp[m][n];}

写在最后

----OK,今日份的博客就写到这里,这一期的动态规划好难想,明天继续加油!!!
—还没看下期的题,但是我的栈还有一节没写;
–追不上时间进度了!!又欠了三天的(笑
-🈚️。

http://www.ds6.com.cn/news/4166.html

相关文章:

  • 泗水做网站怎么申请建立网站
  • 宁波网站建设报价多少seo外链推广工具下载
  • 网站解析如何创建公司网站
  • .net网站模板免费开源代码网站
  • 一个网站怎么做appseo搜索引擎优化ppt
  • 网络seo是什么工作网站排名优化培训
  • 网站开发需要什么东西如何提高网站在搜索引擎中的排名
  • 政务公开微信网站开发方案书网络推广哪个平台最好
  • 如何网站做专题怎么推广自己的微信
  • 哪个网站可以专门做超链接宁波网络营销策划公司
  • 郑州公司做网站汉狮今日头条新闻10条
  • 黄山旅游攻略 知乎朝阳seo排名
  • 国内互动网站建设企业宣传片视频
  • 绵阳市网站建设公司免费seo技术教程
  • 做游戏ppt下载网站线上推广平台有哪些
  • 福州做网站哪家公司好线上推广渠道
  • wordpress 作品相册宁波seo网络推广定制多少钱
  • 北京做网站软件网站编辑
  • 中文网站域名注册百度竞价排名技巧
  • 谷歌云 阿里云 做网站seo营销推广平台
  • 邯郸网站设计制作windows优化大师的作用
  • wordpress 下载服务器windows优化大师好用吗
  • 在哪一个网站上做劳务合同备案百度allin 人工智能
  • 做海报文案的参考网站采集站seo赚钱辅导班
  • 对网站进行seo优化淘宝权重查询
  • 筋郑州做网站竞价推广账户竞价托管收费
  • wordpress前台编辑器网站优化方法
  • 网站创建怎么做怎么创建自己的免费网址
  • 商业广告创意设计seo优化前景
  • 网站开发计划书范文大量微信群推广代发广告