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

有什么推荐做简历的网站抚州seo排名

有什么推荐做简历的网站,抚州seo排名,中国新闻社山西分社,电子商务网站建设的平台1049. 最后一块石头的重量 II 文章 有一堆石头&#xff0c;每块石头的重量都是正整数。 每一回合&#xff0c;从中选出任意两块石头&#xff0c;然后将它们一起粉碎。假设石头的重量分别为 x 和 y&#xff0c;且 x < y。那么粉碎的可能结果如下&#xff1a; 如果 x y&a…

1049. 最后一块石头的重量 II

文章

有一堆石头,每块石头的重量都是正整数。

每一回合,从中选出任意两块石头,然后将它们一起粉碎。假设石头的重量分别为 x 和 y,且 x <= y。那么粉碎的可能结果如下:

如果 x == y,那么两块石头都会被完全粉碎;

如果 x != y,那么重量为 x 的石头将会完全粉碎,而重量为 y 的石头新重量为 y-x。

最后,最多只会剩下一块石头。返回此石头最小的可能重量。如果没有石头剩下,就返回 0。

示例:

输入:[2,7,4,1,8,1]
输出:1
解释:

组合 2 和 4,得到 2,所以数组转化为 [2,7,1,8,1],
组合 7 和 8,得到 1,所以数组转化为 [2,1,1,1],
组合 2 和 1,得到 1,所以数组转化为 [1,1,1],
组合 1 和 1,得到 0,所以数组转化为 [1],这就是最优值。
提示:

1 <= stones.length <= 30
1 <= stones[i] <= 1000

和416. 分割等和子集 (opens new window)非常像了,尽可能平均分。

class Solution {
public: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];}
};

494. 目标和

文章
给定一个非负整数数组,a1, a2, …, an, 和一个目标数,S。现在你有两个符号 + 和 -。对于数组中的任意一个整数,你都可以从 + 或 -中选择一个符号添加在前面。

返回可以使最终数组和为目标数 S 的所有添加符号的方法数。

示例:

输入:nums: [1, 1, 1, 1, 1], S: 3
输出:5
解释:

-1+1+1+1+1 = 3
+1-1+1+1+1 = 3
+1+1-1+1+1 = 3
+1+1+1-1+1 = 3
+1+1+1+1-1 = 3
一共有5种方法让最终目标和为3。

提示:

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

left + right = sum,而sum是固定的。right = sum - left
公式来了, left - (sum - left) = target 推导出 left = (target + sum)/2 。
所有元素凑成left有多少种方法 组合问题
dp[i][j] dp1-i凑成j的方法个数
dp[i][j]=dp[i-1][j-nums[i]]+dp[i-1][j]
一维:dp[j]=dp[j-nums[i]+dp[j] 注意从后往前

注意这种情况: bagSize = (S + sum) / 2 小于0 此时 没有结果。

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];}
};

474.一和零

文章讲解

给你一个二进制字符串数组 strs 和两个整数 m 和 n 。

请你找出并返回 strs 的最大子集的大小,该子集中 最多 有 m 个 0 和 n 个 1 。

如果 x 的所有元素也是 y 的元素,集合 x 是集合 y 的 子集 。

示例 1:

输入:strs = [“10”, “0001”, “111001”, “1”, “0”], m = 5, n = 3

输出:4

解释:最多有 5 个 0 和 3 个 1 的最大子集是 {“10”,“0001”,“1”,“0”} ,因此答案是 4 。 其他满足题意但较小的子集包括 {“0001”,“1”} 和 {“10”,“1”,“0”} 。{“111001”} 不满足题意,因为它含 4 个 1 ,大于 n 的值 3 。

示例 2:

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

1 <= strs.length <= 600
1 <= strs[i].length <= 100
strs[i] 仅由 ‘0’ 和 ‘1’ 组成
1 <= m, n <= 100

题目的关键是将0和1拆解开
dp[i] [jm] [jn]=max( dp[i-1] [jm-nums0[i]] [jn-nums1[i]] +1 , dp[i-1] [jm] [jn]
初始化:0
从后往前

class Solution {
public:int findMaxForm(vector<string>& strs, int m, int n) {vector<vector<int>> dp(m+1,vector<int>(n+1,0));for(auto str:strs){int num1=0;int num0=0;for(auto c :str){if (c == '0') num0++;else num1++;}for(int i=m;i>=num0;i--){for(int j=n;j>=num1;j--){dp[i][j]=max(dp[i][j],dp[i-num0][j-num1]+1);}}}return dp[m][n];}
};
http://www.zhongyajixie.com/news/20179.html

相关文章:

  • 微网站 html5百度网址是多少 百度知道
  • 设计网站轮廓模板培训心得体会1000字通用
  • 网站的文本链接怎么做站长工具seo源码
  • 做家政的在哪些网站推广我想做地推怎么找渠道
  • 公司微信网站开发平台3seo
  • 淘宝客怎么做直播网站google永久免费的服务器
  • 关于党建微网站建设经费的报告西安做推广优化的公司
  • ps做图游戏下载网站有哪些内容网络广告推广
  • 网站的术语湖南网站seo公司
  • 河南招投标信息网百度词条优化
  • 阎良网站建设英文站友情链接去哪里查
  • 佛山网站建设网站建设收费谷歌seo排名公司
  • 鞋图相册网站怎么做百度收录软件
  • 快速建网站今日头条新闻最全新消息
  • 音乐网站建设目标什么是网络营销公司
  • 和田哪里有做网站的地方工具刷网站排刷排名软件
  • 西安网站网络营销沧州网站推广优化
  • 做棋牌网站建设多少钱求网址
  • 奉贤做网站制作企业网站建设的步骤
  • 天站网站建设友情链接平台网站
  • 手机网站设计创意说明网络优化app哪个好
  • 天津狐臭在哪里做津门网站I百度怎么发广告
  • 网站建设的开发方式购物链接
  • 网络营销推广的问题结构优化是什么意思
  • 帮人管理网站做淘宝客西安网站快速排名提升
  • 徐州建设工程交易谷歌seo关键词排名优化
  • wordpress 关闭工具栏企业专业搜索引擎优化
  • 网站建设项目策划书格式如何进行搜索引擎优化
  • 做网站要考虑的太原百度搜索排名优化
  • 建网站做淘宝客赚钱吗个人怎么做网络推广