写这题的时候没有啥DFS思路,感觉还是DFS没刷明白,还需要多提高
参考链接:
【还得用回溯算法!| LeetCode:17.电话号码的字母组合-哔哩哔哩】 https://b23.tv/oTuy71C
class Solution {
public List<String> letterCombinations(String digits) {
List<String> ans=new ArrayList<>();
if(digits==null||digits.length()==0){
return ans;
}
char[] ch=digits.toCharArray();
Map<Integer,String> map=new HashMap<>();
map.put(2,"abc");
map.put(3,"def");
map.put(4,"ghi");
map.put(5,"jkl");
map.put(6,"mno");
map.put(7,"pqrs");
map.put(8,"tuv");
map.put(9,"wxyz");
StringBuilder sb=new StringBuilder();
dfs(ch,map,ans,sb,0);
return ans;
}
public void dfs(char[] ch,Map<Integer,String> map,List<String> ans,StringBuilder sb,int index){
if(index==ch.length){
ans.add(sb.toString());
// sb.setLength(0);
return;
}
String curStr = map.get(ch[index]-'0');
int n=curStr.length();
for(int i=0;i<n;++i){
sb.append(curStr.charAt(i));
dfs(ch,map,ans,sb,index+1);
sb.deleteCharAt(sb.length()-1);
}
}
}
原文地址:https://blog.csdn.net/weixin_46028606/article/details/134635024
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_1895.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。