408算法题leetcode--第29天

17. 电话号码的字母组合

题目地址

题解思路:回溯

时间复杂度:O(3^m * 4^n)

空间复杂度:O(3^m * 4^n)

代码:

cpp 复制代码
class Solution {
public:
    // map digit to word
    string digit_to_word[10] = {
        "", // 0
        "", // 1
        "abc", // 2
        "def", // 3
        "ghi", // 4
        "jkl", // 5
        "mno", // 6
        "pqrs", // 7
        "tuv", // 8
        "wxyz", // 9
    };

    vector<string>ret;
    string str;

    void backtrack(string& digits, int start){
        if(start == digits.size()){
            ret.push_back(str);
            return ;
        }
        int id = digits[start] - '0';
        string temp = digit_to_word[id];
        int size = temp.size();
        for(int i = 0; i < size; i++){
            str += temp[i];
            backtrack(digits, start + 1);
            str.pop_back();
        }
    }

    vector<string> letterCombinations(string digits) {
        // 1. 返回类型和参数
        // 2. 终止
        // 3. 单层循环
        if(digits.empty()) return ret;
        backtrack(digits, 0);
        return ret;
    }
};

39. 组合总和

题目地址39. 组合总和 - 力扣(LeetCode)

题解思路:回溯

时间复杂度 :O(n * 2n),n个数,每个数考虑选or不选(2n)

空间复杂度:O(target)

代码:

cpp 复制代码
class Solution {
public:
    vector<vector<int>>ret;
    vector<int>arr;

    void backtrack(vector<int>& candidates, int target, int sum, int start){
        if(sum > target){
            return ;
        }
        if(sum == target){
            ret.push_back(arr);
            return ;
        }
        int size = candidates.size();
        for(int i = start; i < size; i++){
            arr.push_back(candidates[i]);
            backtrack(candidates, target, sum + candidates[i], i);
            arr.pop_back();
        }
    }

    vector<vector<int>> combinationSum(vector<int>& candidates, int target) {
        // 组合问题:回溯 + 剪枝
        backtrack(candidates, target, 0, 0);
        return ret;
    }
};
相关推荐
洛水水21 分钟前
【力扣100题】76.搜索插入位置
数据结构·算法·leetcode
Techblog of HaoWANG25 分钟前
智巡守卫:多模态巡检智能体算法服务端设计与实现——基于Ollama+Qwen3.5的自动化巡检报告生成系统
运维·人工智能·算法·目标检测·自动化·边缘计算
小蒋学算法35 分钟前
算法-灌溉花园的最少龙头数目-贪心
算法
满怀冰雪35 分钟前
第07篇-差分算法-高效处理区间修改问题
数据结构·算法
KaMeidebaby37 分钟前
卡梅德生物技术快报|重组蛋白的表达和纯化:工艺调试全记录:大肠杆菌体系重组蛋白的表达和纯化参数标定(肠激酶轻链案例)
前端·人工智能·算法·数据挖掘·数据分析
ZPC82101 小时前
如何将机械臂末端定位精度提升至微米如何进行标定
人工智能·算法·机器人
wabs6661 小时前
关于动态规划【力扣343.整数拆分的递推公式怎么理解?】
算法·leetcode·动态规划
测试狗科研平台1 小时前
第一性原理CO2还原反应计算流程和软件推荐
科技·算法·云计算
SEO_juper1 小时前
2026 谷歌 SEO&GEO 常见问题合集:收录、排名、内容、技术全解析
算法·谷歌·常见问题·seo·跨境电商·外贸·geo
叫我:松哥1 小时前
基于卷积神经网络的静态手势语识别算法,在测试集上的识别准确率达到97.5%
人工智能·python·深度学习·神经网络·算法·cnn