IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> LeetCode - 解题笔记 - 216 - Combination Sum III -> 正文阅读

[数据结构与算法]LeetCode - 解题笔记 - 216 - Combination Sum III

Solution 1

本题是对 0040. Combination Sum II 的扩展,但借了 0077. Combination 的核心,即固定候选数字的个数且不放回,选择满足target的方案。

所以本题仍然是dfs搜索,但是使用 0077. Combination 的按尺寸的枚举方案,并且在深入过程中维护当前累加值acc和target的差距,并且在满足条件的终止条件同时判定枚举序列尺寸和acc与target的关系。

  • 时间复杂度: O ( ( n k ) × k ) O(\binom{n}{k} \times k) O((kn?)×k),所有 ( n k ) \binom{n}{k} (kn?)中情形,注意这里的n是可用数字范围(本题是9)而非输入的n,每种需要k长度规模的遍历
  • 空间复杂度: O ( n ) O(n) O(n),temp数组最大占用为k,但是递归占用可能会达到n
class Solution {
public:
    vector<vector<int>> combinationSum3(int k, int n) {
        vector<vector<int>> ans;
        vector<int> temp;
        
        this->dfs(1, 9, k, n, 0, temp, ans);
        
        return ans;
    }
    
private:
    void dfs(int pos, int n, int k, int target, int acc, vector<int> & temp, vector<vector<int>> & ans) {
        // 这里的n是遍历数组的长度(本题始终为9),sum才是输入的n
        if (temp.size() + (n - pos + 1) < k) {
            return;
        }
        if (temp.size() == k && acc == target) {
            ans.emplace_back(temp);
            return;
        }
        
        if (pos == n + 1) {
            return;
        }
        
        temp.emplace_back(pos);
        dfs(pos + 1, n, k, target, acc + pos, temp, ans);
        temp.pop_back();
        dfs(pos + 1, n, k, target, acc, temp, ans);
    }
};

Solution 2

Solution 1的Python实现

class Solution:
    def combinationSum3(self, k: int, n: int) -> List[List[int]]:
        ans = []
        temp = []
        
        self._dfs(1, 9, k, n, 0, temp, ans)
        
        return ans
        
    def _dfs(self, pos: int, n: int, k:int, target:int, acc:int, temp: List[int], ans: List[List[int]]) -> None:
        # 这里的n是遍历数组的长度(本题始终为9),sum才是输入的n
        if len(temp) + (n - pos + 1) < k:
            return
        
        if len(temp) == k and target == acc:
            ans.append(copy.deepcopy(temp))
            return
        
        if pos == n + 1:
            return 
        
        temp.append(pos)
        self._dfs(pos + 1, n, k, target, acc + pos, temp, ans)
        temp.pop()
        self._dfs(pos + 1, n, k, target, acc, temp, ans)
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-11-05 00:49:40  更:2022-11-05 00:52:41 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/25 19:28:48-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码