当前位置: 首页 > article >正文

408算法题leetcode--第29天

17. 电话号码的字母组合

题目地址

题解思路:回溯

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

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

代码:

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)

代码:

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;
    }
};

http://www.kler.cn/news/340953.html

相关文章:

  • 如何让你的Mac右键菜单栏更加的丰富多样
  • Vue vben admin开源库中table组件tips
  • 数据结构进阶:二叉搜索树_C++
  • YOLO11 实例分割模型做行人分割
  • 【10086网上营业厅-注册/登录安全分析报告】
  • 【网络篇】计算机网络——应用层详述(笔记)
  • 华为S5735交换机配置脚本
  • vue 的属性绑定
  • APP的命令和monkey压力测试
  • js基础速成14-错误处理
  • 鸿蒙HarmonyOS中Image图片组件以及HarmonyOs图标库完全解析
  • 社工字典生成工具 —— CeWL 使用手册
  • RabbitMQ初识
  • JavaScript-API(倒计时的实现)
  • 【漏洞复现】宏景-HCM KhFieldTree Sql注入漏洞
  • MySQL 是否支持 XML
  • ISCC认证是什么?ISCC认证的申请流程有哪些注意事项?
  • VBA高级应用30例应用3Excel中的ListObject对象:选择表的一部分
  • 团标大数据(2024年09月)
  • PWR电源控制