【DFS】LeetCode 17. 电话号码的字母组合

Halo,这里是Ppeua。平时主要更新C语言,C++,数据结构算法...感兴趣就关注我bua!

目录

题目:

示例:

题解:

这是一道全排列的问题,先来看看示例.

看第一个示例:输入"23",其对应的是"abc"与"de".根据全排列的特点,我们先把它们按层状结构写开,之后依次排列组合即可

具体的有:

++先选取第零层("abc")中的一个,之后选取第一层("de")中的一个,这时候到了第二层,此时层数等于输入的"23"的size(),说明当前趟排列结束.则存储答案,并返回上一层开始继续下一个排列.++

下面来看看具体的代码实现:

代码实现:

cpp 复制代码
#include<iostream>
#include<vector>
using namespace std;
class Solution {
public:
    string a[10]={"","","abc","def","ghi","jkl","mno","pqrs","tuv","wxyz"}; 
    void conbinStr(string digits,int level,string combine,vector<string>&v)
    {
        if(level==digits.size())
        {
            v.push_back(combine);
            return ;
        }
        int num=digits[level]-'0';
        string str=a[num];

        for(int i=0;i<str.size();i++)
        {
            conbinStr(digits,level+1,combine+str[i],v);
        }
    }
    vector<string> letterCombinations(string digits) {
        vector<string>ans;
        if(digits.size()==0)
        {
            return ans;
        }
        conbinStr(digits,0,"",ans);
        return ans;
    }
};
  1. 先理清整体思路,我们需要进行深搜,但是letterCombinations的参数并不能满足我们的需求,所以我们需要自定义一个函数.Digits(题给字符串 ), Level(层数 ),Combine(组合字符串 ),v(答案数组 ),我们定义一个字符串,用来对应每一个按键所带的字母

  2. 之后开始层状调用

相关推荐
咩咩不吃草7 分钟前
机器学习不平衡数据处理三招:k折交叉验证、下采样与过采样实战
人工智能·算法·机器学习·下采样·过采样·k折交叉验证
weixin_452159558 分钟前
模板编译期条件分支
开发语言·c++·算法
多恩Stone9 分钟前
【3DV 进阶-11】Trellis.2 数据处理与训练流程图
人工智能·pytorch·python·算法·3d·aigc·流程图
老师用之于民10 分钟前
【DAY20】数据结构基础:(算法)排序、折半查找的函数实现
数据结构·算法·排序算法
一起养小猫13 分钟前
Flutter for OpenHarmony 进阶:推箱子游戏算法与关卡设计深度解析
算法·flutter·游戏
民乐团扒谱机14 分钟前
【微实验】Zhang-Suen 快速并行细化算法与MATLAB实现
人工智能·学习·算法·计算机视觉·数学建模·matlab
iAkuya17 分钟前
(leetcode)力扣100 60单词搜索(回溯)
算法·leetcode·职场和发展
卖报的大地主18 分钟前
强化学习在图像生成中的应用:范式演进、算法机制与前沿展望
算法
圣保罗的大教堂21 分钟前
leetcode 3637. 三段式数组 I 简单
leetcode
ʚB҉L҉A҉C҉K҉.҉基҉德҉^҉大22 分钟前
C++中的策略模式进阶
开发语言·c++·算法