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

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

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



题目:


1e65d3dfae2c4a93a63d9cddaba96df8.png



示例:


5cec6fefc0124f0e98aba909a89dfc83.png


题解:


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


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


具体的有:


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


ad0e076adc3548b3956c24c917e2e025.jpg


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


代码实现:


#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.之后开始层状调用


e64788fcf1dd4dafa58c7e6b16ccc39f.jpg

目录
相关文章
|
2天前
|
算法 测试技术 C#
【单调栈】LeetCode2030:含特定字母的最小子序列
【单调栈】LeetCode2030:含特定字母的最小子序列
|
2天前
leetcode代码记录(第一个出现两次的字母
leetcode代码记录(第一个出现两次的字母
11 2
|
2天前
leetcode代码记录(有效的字母异位词
leetcode代码记录(有效的字母异位词
10 1
|
2天前
|
存储 编译器 Linux
标准库中的string类(中)+仅仅反转字母+字符串中的第一个唯一字符+字符串相加——“C++”“Leetcode每日一题”
标准库中的string类(中)+仅仅反转字母+字符串中的第一个唯一字符+字符串相加——“C++”“Leetcode每日一题”
|
2天前
【力扣】1832.判断句子是否为全字母句
【力扣】1832.判断句子是否为全字母句
|
2天前
leetcode热题100. 字母异位词分组
leetcode热题100. 字母异位词分组
18 0
|
2天前
|
Java
LeetCode-电话号码的字母组合-Java
电话号码的字母组合-Java
15 0
|
2天前
|
算法
LeetCode题:581. 最短无序连续子数组,242. 有效的字母异位词,202. 快乐数
LeetCode题:581. 最短无序连续子数组,242. 有效的字母异位词,202. 快乐数
29 0
|
2天前
代码随想录Day30 贪心05 LeetCode T435无重叠区间 T763划分字母区间 T56 合并区间
代码随想录Day30 贪心05 LeetCode T435无重叠区间 T763划分字母区间 T56 合并区间
32 0
|
2天前
|
算法 C++
【刷题】Leetcode 1609.奇偶树
这道题是我目前做过最难的题,虽然没有一遍做出来,但是参考大佬的代码,慢慢啃的感觉的真的很好。刷题继续!!!!!!
9 0