动态规划-似包非包问题

组合总和 Ⅳ(377)

题目描述:
在这里插入图片描述

状态表示:
我们看到这题发现有一个限制条件就是目标整数target并且此时数组中的数字是可以重复选择的,这时候不难联想到前面学习的完全背包问题,这题好像符合完全背包问题的条件。但是事实上不是这样的,因为背包问题是一个组合问题,在选择的过程中不会去要求顺序,这题的题目也有一定的误导性即组合求和。然而这题是一个排列问题,对于选择的数字是有顺序的要求的。
我们建立一维数组dp,使用dp[i]来表示总和达到i时的数字的排列数。
状态转移方程:
对于每个dp[i],都要遍历nums数组,当i-nums[j]>=0时,dp[i]+=dp[i-nums[j]],因为经过判断后下标值是合法的,我们可以正常更新dp的值,将所有的排列可能累加起来得到最终的结果。
初始化:
为了能够使得dp数组能够正常更新数据,初始化dp[0]=1,此时要满足的数就是0,我们可以选择的排列就是一个空集,所以初始化为1。
填表顺序:
显而易见,从左至右。
返回值:
我们初始化dp数组的长度为target+1,所以返回值为dp[target].
代码如下:

class Solution {public int combinationSum4(int[] nums, int target) {int n = nums.length;int[] dp = new int[target + 1];dp[0] = 1;for (int i = 1; i <= target; i++) {for (int j = 0; j < n; j++) {if (i >= nums[j]) {dp[i] += dp[i - nums[j]];}}}return dp[target];}
}

题目链接
时间复杂度:O(N^2)
空间复杂度:O(N)

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

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

相关文章

关于linux磁盘告警问题

案例&#xff1a;我们在执行df命令时&#xff0c;查看到磁盘利用率很高&#xff0c;但是到相对应的目录执行du -sh *来找大文件时进行删除时&#xff0c;发现各个目录相加并不大&#xff0c;如下图&#xff1a; 使用df命令查看到根(/)目录使用到33G&#xff0c;而du命令显示只使…

vscode终端命令行前面出现两个conda环境名的问题决解方法

已经安装了conda&#xff0c;打开vscode的terminal时&#xff0c;命令行前面有两个虚拟环境名。 进入vscode的setting 找到Python->Python:Default Interpreter Path&#xff0c;把这个值复位&#xff0c;就可以解决。 如果不想前面带(base)&#xff0c;可以运行 conda co…

FLIP动画思想

Aerotwist - FLIP Your Animations 还可以用gsap动画库的FLIP插件 Flip | GSAP | Docs & Learning // Get the first position. var first el.getBoundingClientRect();// Now set the element to the last position. el.classList.add(totes-at-the-end);// Read agai…

STP简介

一、STP介绍 STP 即生成树协议&#xff08;Spanning Tree Protocol&#xff09;一种网络协议 STP 主要用于解决以太网中的环路问题。在具有冗余链路的网络环境中&#xff0c;环路可能导致广播风暴、重复帧等不良后果&#xff0c;严重影响网络性能和稳定性。STP 通过在交换机之…

FuTalk设计周刊-Vol.050

#AI漫谈 热点捕手 1.Canva 宣布收购 Affinity 创意套件 平面设计平台 Canva 于 3 月 26 日宣布收购知名设计软件 Affinity 以“迎战”Adobe&#xff0c;不过此后许多设计师开始担心原本采用“永久授权”付费方案的 Affinity 系列软件是否会转为订阅制&#xff0c;而目前 Canv…

Android Studio开发之路(十四)自定义Titlebar以及设置顶部状态栏颜色

一、描述 项目需求&#xff0c;我要做一个下图这样的titlebar,包括一个返回按钮&#xff0c;一个关闭按钮&#xff0c;一个文本框。默认的titlebar按钮设计不太满足我的需求&#xff0c;于是我打算自定义一个titlebar组件&#xff0c;应用到我的每一个页面 二、titlebar组件设…

【NumPy】关于numpy.searchsorted()函数,看这一篇文章就够了

&#x1f9d1; 博主简介&#xff1a;阿里巴巴嵌入式技术专家&#xff0c;深耕嵌入式人工智能领域&#xff0c;具备多年的嵌入式硬件产品研发管理经验。 &#x1f4d2; 博客介绍&#xff1a;分享嵌入式开发领域的相关知识、经验、思考和感悟&#xff0c;欢迎关注。提供嵌入式方向…

【Qt】数据库(一)SQLITE创建、增删查改

填坑1&#xff1a;如何连续插入 汇总SQlite语句 创建表格&#xff1a;create table <table_name> (f1 type1, f2 type2,…); 增&#xff1a;insert into <table_name> values (value1, value2,…); 改&#xff1a;update <table_name> set <f1value1>,…

AttributeError: module ‘google._upb._message‘ has no attribute ‘Message‘

rolling back to the stable version protobuf3.20.1 resolved the issue for me.

数据结构第二篇【关于java线性表(顺序表)的基本操作】

【关于java线性表&#xff08;顺序表&#xff09;的基本操作】 线性表是什么&#xff1f;&#x1f435;&#x1f412;&#x1f98d;顺序表的定义&#x1f9a7;&#x1f436;&#x1f435;创建顺序表新增元素,默认在数组最后新增在 pos 位置新增元素判定是否包含某个元素查找某个…

.net aot inherit object.Dispose()”: 没有找到适合的方法来重写解决方法

.net aot inherit object.Dispose()”: 没有找到适合的方法来重写解决方法<DisableImplicitFrameworkReferences>true</DisableImplicitFrameworkReferences>

【Python爬虫】案例_百度贴吧

声明&#xff1a;案例只用于学习&#xff0c;不得恶意使用 要求&#xff1a;获取帖子的标题和链接 import requests from lxml import etreeclass Tieba(object):def __init__(self,name):self.url https://tieba.baidu.com/f?ieutf-8&kw{}.format(name)self.headers …

人形机器人建模与控制(三) - 机器人控制

L3 Robot Control Robot Control L3 Robot Control1. RepeatForward KinematicsDifferential KinematicsExternal Wrench (Force & Torque) MappingDynamicsGoal for Today2. Feedback Cancellation3. Joint Space ControlSimpler Control Laws

JDBC批量处理(addBatch/executeBatch/clearBatch)

1-操作多条的时候用批量处理&#xff0c;比单条处理效率更高 2-JDBC常用批量处理方法 &#xff08;1&#xff09;addBatch(string)&#xff1a;添加批量处理的sql语句或参数 &#xff08;2&#xff09;executeBatch&#xff1a;执行批量处理语句 &#xff08;3&#xff09;clea…

Java中IO的四大抽象类

InputStream/OutputStream和Reader/Writer类是所有IO流类的抽象父类&#xff0c;需要先简单了解一下这四个抽象类的作用。然后&#xff0c;通过它们具体的子类熟悉相关的用法。 InputStream 此抽象类是表示字节输入流的所有类的父类。InputStream是一个抽象类&#xff0c;它不…

BUG(18) : Caused by: java.lang.ClassNotFoundException

场景 导入了多个mave依赖, 启动是报java.lang.ClassNotFoundException, 报错位置为依赖包里面的子依赖 解决 什么依赖报错, pom文件直接引入该子依赖

代码随想录算法训练营第二十天 | 654.最大二叉树 、617.合并二叉树、700.二叉搜索树中的搜索、98.验证二叉搜索树

654.最大二叉树 题目链接&#xff1a;https://leetcode.cn/problems/maximum-binary-tree/ 文档讲解&#xff1a;https://programmercarl.com/0654.%E6%9C%80%E5%A4%A7%E4%BA%8C%E5%8F%89%E6%A0%91.html 视频讲解&#xff1a;https://www.bilibili.com/video/BV1MG411G7ox 思路…

使用高性能NIO框架netty实现IM集群对聊方案

文章目录 前言技术积累什么是nettynetty如何实现IM如何实现IM集群 实战演示基础配置netty搭建IM集群redis发布订阅 实战测试 前言 在前面的博文中我们分享了原生websoket集群搭建&#xff0c;也用redis 发布订阅实现了集群消息正常有序分发。但是有不少同学希望风向一期netty实…

Json差异比较

json差异比较 如何比较两个json的差异 代码实现 导入依赖 <dependency><groupId>cn.xiaoandcai</groupId><artifactId>json-diff</artifactId><!-- 旧版本可能存在某些缺陷。版本请以maven仓库最版为准。 --><version>4.1.3-RC1-R…

问题记录_stm32“No target connected“

问题描述&#xff1a; 基于HAL库和stm32cubeMX生成的代码&#xff0c;烧录时出现如下报错窗口&#xff1a; 问题原因&#xff1a; stm32cubeMX生成代码时关闭了SWJ调试功能 解决方法&#xff1a; 在项目中找到__HAL_AFIO_REMAP_SWJ_DISABLE();并注释掉 然后短按复位键的…