​LeetCode刷题实战377:组合总和 Ⅳ

news/2024/11/24 19:14:52/

算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试。所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 !

今天和大家聊的问题叫做 组合总和 Ⅳ,我们先来看题面:

https://leetcode-cn.com/problems/find-k-pairs-with-smallest-sums/

Given an array of distinct integers nums and a target integer target, return the number of possible combinations that add up to target.

The answer is guaranteed to fit in a 32-bit integer.

给你一个由 不同 整数组成的数组 nums ,和一个目标整数 target 。请你从 nums 中找出并返回总和为 target 的元素组合的个数。

题目数据保证答案符合 32 位整数范围。

示例

示例 1:输入:nums = [1,2,3], target = 4
输出:7
解释:
所有可能的组合为:
(1, 1, 1, 1)
(1, 1, 2)
(1, 2, 1)
(1, 3)
(2, 1, 1)
(2, 2)
(3, 1)
请注意,顺序不同的序列被视作不同的组合。示例 2:输入:nums = [9], target = 3
输出:0

解题

动态规划

本题第一眼以为是dfs,但是实在想不出来下标怎么处理

dp数组的意义:dp[i]代表'target = i'时的组合数目,显然此时dp数组的初始化长度为target+1。

遍历规则:1 <= i <= target, ++i,target值从小到大。内层遍历是遍历nums数组。

更新规则:dp[i] += dp[i-num],隐含的含义是若当前i >= num,那么可以在dp[i-num]加入num,组合为一个完整组合。

边界条件:dp[0] = 1,当i == num,代表本身数字是一个组合,因此dp[0]需等于1。

class Solution {
public:int combinationSum4(vector<int>& nums, int target) {// dp[i]:target为i时的组合数目vector<int> dp(target+1, 0);dp[0] = 1;for(int i = 1; i < target + 1;++i){for(auto num:nums){if(num <= i && dp[i-num] < INT_MAX - dp[i]) // 防止越界dp[i] += dp[i - num];}}return dp[target];}
};

好了,今天的文章就到这里,如果觉得有所收获,请顺手点个在看或者转发吧,你们的支持是我最大的动力 。

上期推文:

LeetCode1-360题汇总,希望对你有点帮助!

LeetCode刷题实战361:轰炸敌人

LeetCode刷题实战362:敲击计数器

LeetCode刷题实战363:矩形区域不超过 K 的最大数值和

LeetCode刷题实战364:加权嵌套序列和 II

LeetCode刷题实战365:水壶问题

LeetCode刷题实战366:寻找二叉树的叶子节点

LeetCode刷题实战367:有效的完全平方数

LeetCode刷题实战368:最大整除子集数

LeetCode刷题实战369:给单链表加一

LeetCode刷题实战370:区间加法

LeetCode刷题实战371:两整数之和

LeetCode刷题实战372:超级次方

LeetCode刷题实战373:查找和最小的K对数字

LeetCode刷题实战374:猜数字大小

LeetCode刷题实战375:猜数字大小 II

LeetCode刷题实战376:摆动序列


http://www.ppmy.cn/news/276777.html

相关文章

v语言怎么玩

直接上github: https://github.com/vlang/v 前戏 大概是在6月份的时候,在github上看到了这个玩意,我以为是??? V字仇杀队 ?? 我下意识的去查了一下有没有人在讨论这个语言,但是关于这货的在国内讨论比较少 噱头如下: Simplicity: the language can be learned in less tha…

V 字仇杀队(V for Vendetta)

如果 50 年后有人撰写世界电影的编年史&#xff0c; 2006 年的代表电影应该有 《V 字仇杀队》的一席之地。 这部电影注定要和《1984》扯上关系&#xff0c;那个无所不在的”伦敦之声”让你没办法不和”老大哥”联想在一起; 没有人知道真相是怎样&#xff0c;真理掌握在少数人手…

电影之记忆1:V字仇杀队

讲述一个时代的政治体系的由来&#xff01; 主人公在里面是政治的悲剧产物&#xff01; 电影讲述了通过个人力量唤醒公众推翻政党的故事&#xff01; 很喜欢主人公说话的语气&#xff01;给我印象非常深&#xff01; 希望你喜欢&#xff01;希望看过后给点评价&#xff01;

九度oj 题目1364:v字仇杀队

题目描述&#xff1a; 最近玄影游侠看了一部非常好看的电影&#xff0c;叫做《v字仇杀队》。下面是这部电影的主角v&#xff1a; 它想说明的一个问题就是&#xff0c;你现在所想的真的是你自己内心所想的吗&#xff1f;还是别人&#xff0c;社会让你这么想的&#xff1f;你要有…

九度笔记之 1364:v字仇杀队

题目1364&#xff1a;v字仇杀队 时间限制&#xff1a;1 秒 内存限制&#xff1a;32 兆 特殊判题&#xff1a;否 提交&#xff1a;302 解决&#xff1a;109 题目描述&#xff1a; v整整策划了一年炸掉英国政府的大楼来推翻独裁统治&#xff0c;在这期间&#xff0c;v遇到了一个问…

九度 1364 v字仇杀队

http://ac.jobdu.com/problem.php?id1364 经典01背包&#xff0c;没有用空间逆序优化。 1 #include <stdio.h> 2 #include <string.h> 3 #include <stdlib.h> 4 int S,C; 5 int force[102]; 6 int space[102]; 7 int mat[102][1002]; 8 int max(int a,int b…

风青杨:如何解读央视播放《V字仇杀队》?

12月14日晚&#xff0c;CCTV-6破天荒播出电影《V字别动队》&#xff0c;此举在微博上引起热议。有网友甚至惊呼“这样的电影能在央视上映&#xff0c;我一度怀疑自己是在做梦。”这部曾经一度禁播的电影自上映以来首次在大陆公映&#xff0c;该片中的经典台词“人民不应该害怕政…

V字仇杀队精彩简介_免费下载

1、英国历史上有个人叫盖伊福克斯试图炸毁议会大厦&#xff0c;最终被判处绞刑。有一个男人戴上盖伊的面具&#xff0c;全副武装后出门了。与此同时伊薇哈蒙德也打算出门&#xff0c;听到节目主持人一味的洗脑而厌烦的伊薇关上电视&#xff0c;发现已经过了宵禁时间&#xff0c…