首页 > 其他分享 >【DFS】LeetCode 17. 电话号码的字母组合

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

时间:2023-03-02 12:56:56浏览次数:59  
标签:map 17 index stringBuilder char put 字母组合 new LeetCode

题目链接

17. 电话号码的字母组合

思路

使用 DFS 进行枚举。

代码

class Solution {
    private HashMap<Character, char[]> map = new HashMap<>();
    private List<String> result = new ArrayList<>();
    private char[] s;

    public List<String> letterCombinations(String digits) {
        if(digits.equals("")){
            return new ArrayList();
        }

        init();

        s = digits.toCharArray();
        int len = s.length;

        dfs(0, len, new StringBuilder());

        return result;
    }

    private void dfs(int index, int len, StringBuilder stringBuilder) {
        if(index == len){
            result.add(stringBuilder.toString());
            return;
        }

        System.out.println("index = " + index);
        char[] temp = map.get(s[index]);
        for(char c : temp){
            stringBuilder.append(c);
            dfs(index + 1, len, stringBuilder);
            stringBuilder.deleteCharAt(stringBuilder.length() - 1);
        }
    }

    void init(){
        map.put('2', new char[]{'a', 'b', 'c'});
        map.put('3', new char[]{'d', 'e', 'f'});
        map.put('4', new char[]{'g', 'h', 'i'});
        map.put('5', new char[]{'j', 'k', 'l'});
        map.put('6', new char[]{'m', 'n', 'o'});
        map.put('7', new char[]{'p', 'q', 'r', 's'});
        map.put('8', new char[]{'t', 'u', 'v'});
        map.put('9', new char[]{'w', 'x', 'y', 'z'});
    }
}

标签:map,17,index,stringBuilder,char,put,字母组合,new,LeetCode
From: https://www.cnblogs.com/shixuanliu/p/17171408.html

相关文章

  • 【DFS】LeetCode 131. 分割回文串
    题目链接131.分割回文串思路使用DFS,同时依次检查分割的字符串是否是回文串。注意:需要频繁添加删除末尾元素时,可以使用Deque代码classSolution{privateLis......
  • Leetcode——二分法bisect_left,bisect_right
    !前提——列表有序case1如果列表中没有元素x,那么bisect_left(ls,x)和bisec_right(ls,x)返回相同的值,该值是x在ls中“合适的插入点索引,使得数组有序”。此时,ls[index2]......
  • 全球土地利用数据ESRI 10m Annual Land Use Land Cover (2017-2021)介绍及下载
    ESRILandCover10m(2017-2021)土地利用数据介绍及下载数据介绍参考链接:https://livingatlas.arcgis.com/landcover/https://gee-community-catalog.org/projects/e......
  • educational round 1796 D & E 解题报告
    Part1D【题意】有一个数组\(\{a_n\}\),给定\(x,k\),现在要将数组内\(k\)个数加上\(x\),其他的数减去\(x\)。问得到的所有可能数组中最大子段和的最大值。\(1\len......
  • CF1799 解题笔记
    A模拟即可。#include<bits/stdc++.h>#defineILinline#defineregregister#defineN50050ILintread(){regintx=0;regcharch=getchar();while(c......
  • FPGA_8_17
    后处理 黑平衡 De-Bayer德拜耳双线性算法 高斯混合模型(GMM)矩阵系统 y峰c低通滤波器 视频处理LU2 伽马校正算法 亮度增益lumagain 色彩饱和度colorsaturation ......
  • LeetCode算法训练-贪心算法 455.分发饼干 376. 摆动序列 53. 最大子序和
    欢迎关注个人公众号:爱喝可可牛奶LeetCode算法训练-贪心算法455.分发饼干376.摆动序列53.最大子序和前置知识贪心算法核心是找局部最优解,通过局部最优推导出全局最......
  • LeetCode 84. 柱状图中最大的矩形()
    原题解题目约束题解方法一classSolution{public:intlargestRectangleArea(vector<int>&heights){intn=heights.size();vec......
  • LeetCode算法训练-回溯总结
    欢迎关注个人公众号:爱喝可可牛奶LeetCode算法训练-回溯总结适用问题组合问题:N个数里面按一定规则找出k个数的集合排列问题:N个数按一定规则全排列,有几种排列方式切割问......
  • LeetCode算法训练-回溯总结
    欢迎关注个人公众号:爱喝可可牛奶LeetCode算法训练-回溯总结适用问题组合问题:N个数里面按一定规则找出k个数的集合排列问题:N个数按一定规则全排列,有几种排列方式切割......