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

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

题目链接 1049 最后一块石头的重量 II

本题思路用一句话概括本题:其实就是尽量让石头分成重量相同的两堆,相撞之后剩下的石头最小。这样一看和前面的题目一个思路了,下面上代码:

class Solution {
public:int lastStoneWeightII(vector<int>& stones) {int sum = 0;for(int i=0;i<stones.size();i++){sum+=stones[i];}int target;target = sum/2;vector<int> dp(15005,0);//初始化//dp[j]的含义是在容量为j的背包中,取最大价值的石头for(int i=0;i<stones.size();i++){for(int j=target;j>=stones[i];j--){dp[j] = max(dp[j-stones[i]]+stones[i],dp[j]);//这里价值和重量相等}}int result = sum-dp[target]-dp[target];return result;}
};

Leetcode 494. 目标和

题目链接 494 目标和

本题目思路比较难想:

如何转化为01背包问题呢。

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

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

x = (target + sum) / 2

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

要注意dp的含义:dp[j] 表示:填满j(包括j)这么大容积的包,有dp[j]种方法

自身感觉卡哥在视频中没讲清楚,看了一下别人的讲解觉得不错:

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

这个方程的意思是,如果我们要用若干个元素组成和为j的方案数,那么有两种选择:不选第i个元素或者选第i个元素。如果不选第i个元素,那么原来已经有多少种方案数就不变;如果选第i个元素,那么剩下要组成和为j - nums【i】 的方案数就等于dp[j - nums【i】]。所以两种选择相加就是dp【j】。

下面上代码:

class Solution {
public:int findTargetSumWays(vector<int>& nums, int target) {int sum = 0;for(int i=0;i<nums.size();i++){sum+=nums[i];}//两种情况的特判if(abs(target)>sum){return 0;}//奇数不存在if((target+sum)%2 == 1){return 0;}int left = (target+sum)/2;vector<int> dp(left+1,0);dp[0] = 1;for(int i=0;i<nums.size();i++){for(int j=left;j>=nums[i];j--){//dp的含义是取j个元素能得到target的方案数dp[j]=dp[j]+dp[j-nums[i]];}}return dp[left];}
};

Leetcode 474. 一和零

题目链接 474 一和零

本题也是01背包,只不过是两个维度,就是一个三位数组,下面上代码:

class Solution {
public:int findMaxForm(vector<string>& strs, int m, int n) {vector<vector<int>> dp(m+1,vector<int> (n+1,0));for(string str : strs){int z = 0;int y = 0;for(char c : str){//遍历物品if(c == '0'){z++;}else{y++;}}for(int i=m;i>=z;i--){//遍历容量for(int j=n;j>=y;j--){dp[i][j] = max(dp[i-z][j-y]+1,dp[i][j]);}}}return dp[m][n];      }
};

对于01背包又有点迷了,上课回来还要仔细思考一下

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/204563.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

uni-app 微信小程序之好看的ui登录页面(三)

文章目录 1. 页面效果2. 页面样式代码 1. 页面效果 2. 页面样式代码 <!-- 简洁登录页面 --> <template><view class"login-bg"><image class"img-a" src"https://zhoukaiwen.com/img/loginImg/bg1.png"></image>…

K8s 多租户方案的挑战与价值

在当今企业环境中&#xff0c;随着业务的快速增长和多样化&#xff0c;服务器和云资源的管理会越来越让人头疼。K8s 虽然很强大&#xff0c;但在处理多个部门或团队的业务部署需求时&#xff0c;如果缺乏有效的多租户支持&#xff0c;在效率和资源管理方面都会不尽如人意。 本…

为什么 AWS 数据库不讲 HTAP

在 AWS re:Invent 2023 掌门人 Adam Selipsky 的 Keynote 上&#xff0c;数据库方面最重磅的主题是 Zero-ETL&#xff0c;从 TP 数据库 (RDS, Aurora, DynamoDB) 同步数据到 AP 数据库 (Redshift)。 Zero-ETL 是 AWS 在去年 re:invent 2022 上推出的概念&#xff0c;今年则继…

Java爬虫攻略:应对JavaScript登录表单

问题背景 在进行网络抓取数据时&#xff0c;经常会遇到需要登录的网站&#xff0c;特别是使用JavaScript动态生成登录表单的情况。传统的爬虫工具可能无法直接处理这种情况&#xff0c;因此需要一种能够模拟用户行为登录的情况解决方案。 在实际项目中&#xff0c;我们可能需要…

鸿蒙操作系统架构

下面是Android和鸿蒙的主要区别的简要总结&#xff1a; Android鸿蒙开发语言Java、Kotlin鸿蒙开发语言&#xff08;HML、JS、Java等&#xff09;架构单一系统架构分布式系统架构设备适配性需要针对不同设备进行适配支持全场景设备&#xff0c;适配性更高用户界面使用XML布局文…

两个旋转矩阵相乘的李代数扰动求导

有一些非常有意思的求导方式&#xff0c;特此记录下来 1. 2. 所以看起来是个小量&#xff0c;可以去掉的 3. 4. 同样&#xff0c;是个小量

文件的隐藏属性 chattr 和 lsattr 详解

chattr 命令 chattr 命令用于设置文件的隐藏权限&#xff0c;格式为“chattr [参数] 文件”。如果想要把某个隐 藏功能添加到文件上&#xff0c;则需要在命令后面追加“参数”&#xff0c;如果想要把某个隐藏功能移出文件&#xff0c; 则需要追加“-参数”。 命令参数如下&am…

电压放大器可用于什么电路

电压放大器是一种常见的电子器件&#xff0c;其主要功能是放大输入信号的电压幅度。它可以用于多种电路中&#xff0c;下面西安安泰将详细介绍几个典型的应用场景。 首先&#xff0c;电压放大器可以用于音频放大器电路。音频放大器广泛应用于音响设备、电视机、电脑音箱等&…

想转行IT,有前途嘛?30个详细理由中会得到你想要的答案

目录 前言&#xff1a; 一、转行IT的前景 二、IT行业的情况 三、技能需求 四、如何准备转行IT 如果你想转行IT&#xff0c;以下是一些建议&#xff1a; 前言&#xff1a; 转行IT是一个颇具吸引力的选择&#xff0c;尤其在当前社会&#xff0c;IT行业的需求非常广泛。然而…

上证指数计算公式详解

作为中国证券市场的重要代表之一&#xff0c;上证指数&#xff08;Shanghai Composite Index&#xff09;对投资者而言具有重要意义。了解其计算公式&#xff0c;对于理解市场走势和投资决策至关重要。本文将深入探讨上证指数的计算公式&#xff0c;帮助读者更全面地理解这一指…

处理合并目录下的Excel文件数据并指定列去重

处理合并目录下的Excel文件数据并指定列去重 需求&#xff1a;读取指定目录下的Excel文件并给数据做合并与去重处理 Python代码实现 import os import pandas as pd import warnings import time from tqdm import tqdm #进度条展示def read_excel(path):dfs []for file in…

LaTex 数学公式:单个编号连等式

单个编号连等式的 LaTeX 写法如下&#xff1a; %%%%%% Equations %%%%%% \begin{align}L & (a b)^2 \nonumber \\& a^2 2ab b^2 \end{align}LaTex渲染结果如下&#xff1a; L ( a b ) 2 a 2 2 a b b 2 \begin{align} L & (a b)^2 \nonumber \\ &…

MySQL数据库中SQL语句分几类?

SQL语句主要分为四类&#xff0c;分别是数据查询语言&#xff08;DQL&#xff09;、数据操作语言&#xff08;DML&#xff09;、数据定义语言&#xff08;DDL&#xff09;和数据控制语言&#xff08;DCL&#xff09;。 1.数据查询语言&#xff08;DQL&#xff09;&#xff1a;…

word中如何插入公式,如何高效使用mathtype,遇到他人论文的复杂公式如何直接粘贴复制,为你一一答疑解惑!!

文章目录 一、论文中插入公式---最原始&#xff0c;最好用&#xff0c;最稳定的方法1.1 主页--插入---对象1.2 找到公式编辑器&#xff0c;对应你的版本1.3 直接输入公式&#xff0c;关闭界面 二、如何做好一个懒人——如何直接粘贴别人PDF等格式论文中的公式&#xff1f;2.1 使…

UVM:field automation机制

&#xff08;1&#xff09;field automation机制相关的宏 最简单的uvm_field系列宏有如下几 种&#xff1a; define uvm_field_int(ARG,FLAG) define uvm_field_real(ARG,FLAG) define uvm_field_enum(T,ARG,FLAG) define uvm_field_object(ARG,FLAG) define uvm_field_event(…

Nginx反向代理导致请求头丢失

nginx默认request的header的那么中包含’_’时&#xff0c;会自动忽略掉。 解决方法是&#xff1a;在nginx里的nginx.conf配置文件中的http部分中添加如下配置&#xff1a; underscores_in_headers on; &#xff08;默认 underscores_in_headers 为off&#xff09;参考博文&am…

Maven能为我们解决什么问题?

Maven是一个流行的Java项目管理工具&#xff0c;它可以帮助开发人员更有效地管理项目的构建、报告和文档。Maven可以解决以下问题&#xff1a; 项目管理&#xff1a;Maven提供了一个标准的项目结构&#xff0c;使得项目的管理更加有序和一致。它可以帮助开发者组织代码、配置文…

python笔记argmax()

一维数组 返回数组中最大值元素的索引位置 import numpy as np a np.array([6, 2, 3, 10, 12, 1]) print(np.argmax(a)) #输出结果为4 # 也可以这样用 print(a.argmax())二维数组 参数axis可取(0,1)&#xff0c;默认是0&#xff0c;表示数组第几维的最大值。 axis 0&#…

摄像头3A算法概述

摄像头3A算法概述 一、前言二、自动对焦&#xff08;Auto Focus&#xff09;三、自动曝光&#xff08;Auto Exposure&#xff09;四、自动白平衡&#xff08;Auto White Balance&#xff09;五、在自动驾驶中的应用 一、前言 摄像头的3A算法指的是自动对焦&#xff08;Auto Fo…

JPA(Java Persistence API)是什么

JPA的官网地址&#xff1a;https://jcp.org/en/jsr/detail?id338 当前最新的版本是2.2版本&#xff1a;https://jcp.org/aboutJava/communityprocess/mrel/jsr338/index.html JPA是一个Java持久化的API&#xff0c;通过这个API&#xff0c;在Java EE和Java SE 环境中管理持…