Java实现LeetCode17. 电话号码的字母组合
给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。
给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。

示例:
输入:“23”
输出:[“ad”, “ae”, “af”, “bd”, “be”, “bf”, “cd”, “ce”, “cf”].
说明:
尽管上面的答案是按字典序排列的,但是你可以任意选择答案输出的顺序。
第一种方法,纯暴力
每次都把字符加上去存到String ArrayList里,然后用两个int pos和posNow计入当前答案和之前答案的开始位置,循环利用之前答案加一位字母生成新的字符串。
import java.util.LinkedList;
import java.util.List;
public class 电话号码的数字组合 {
public static void main(String[] args) {
String digits="23";
List<String> ans = new LinkedList<String>();
// if(digits.isEmpty()) return ans;//注意空的情况
String sb="";
String[] numToChar = {"abc","def","ghi","jkl","mno","pqrs","tuv","wxyz"};
int[] num = new int[digits.length()];
int count=1;
int now;
String check;
for(int i=0;i<digits.length();i++){
num[i]=numToChar[digits.charAt(i)-'2'].length();
count*=num[i];
}
for(int i=0;i<count;i++){
now = i;
for(int j=0;j<digits.length();j++){
check =numToChar[digits.charAt(j)-'2'];
char a=check.charAt(now%num[j]);//取当前这一组eg:(abc)最大的一个
sb = sb+a;
now/=num[j];
}
ans.add(sb.toString());
// sb.delete( 0, sb.length() );//清空sb
sb="";
}
System.out.println(ans);
}
}
第二种方法
原理就是将每个可能的字符串编码,然后计算出总共可能的数量。
之后遍历0~最大数量间的所有数,每一个数对应一个字符串。然后对这些数字不断取余就是每一个编码对应的每一位的字符编号。然后根据这个编号去数组里找对应字符插入StringBuilder,等编码分析完毕后,一条字符串就好了,可以插入输出StringArrayList中。
import java.util.LinkedList;
import java.util.List;
public class 电话号码的数字组合2 {
static String digits="23";
public static void main(String[] args) {
List<String> ans = new LinkedList<String>();
List<String> result = new LinkedList<String>();
String[] numToChar = {"abc","def","ghi","jkl","mno","pqrs","tuv","wxyz"};
int len = digits.length();
int pos=0;
int posNow=0;
for(int i=0;i<len;i++){
char c = digits.charAt(i);
if(result.size()!=0){
for(int j=pos;j<posNow;j++){
for(int k=0;k<numToChar[c-'2'].length();k++){
System.out.println(result.get(j)+numToChar[c-'2'].charAt(k));
result.add(result.get(j)+numToChar[c-'2'].charAt(k));
}
}
}
else{
for(int k=0;k<numToChar[c-'2'].length();k++){
System.out.println(""+numToChar[c-'2'].charAt(k));
result.add(""+numToChar[c-'2'].charAt(k));
}
}
pos=posNow;
posNow = result.size();
}
for(int i=pos;i<posNow;i++){
ans.add(result.get(i));
}
System.out.println(ans);
}
}
Java实现LeetCode17. 电话号码的字母组合的更多相关文章
- Leetcode13. 罗马数字转整数Leetcode14. 最长公共前缀Leetcode15. 三数之和Leetcode16. 最接近的三数之和Leetcode17. 电话号码的字母组合
> 简洁易懂讲清原理,讲不清你来打我~ 输入字符串,输出对应整数 .注意 1 不对应任何字母. 示例: 输入:"23" 输出:[&quo ...
- leetcode17 电话号码的字母组合 dfs
就dfs吧.... 然后,我傻了.前一道题不用考虑空,这道题就要考虑.... 还有注意vector要引用传递 class Solution { public: void dfs(string temp ...
- Java实现 LeetCode 17 电话号码的字母组合
17. 电话号码的字母组合 给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合. 给出数字到字母的映射如下(与电话按键相同).注意 1 不对应任何字母. 示例: 输入:"23& ...
- [LeetCode] Letter Combinations of a Phone Number 电话号码的字母组合
Given a digit string, return all possible letter combinations that the number could represent. A map ...
- lintcode 中等题:Letter Combinations of a Phone Number 电话号码的字母组合
题目 电话号码的字母组合 给一个数字字符串,每个数字代表一个字母,请返回其所有可能的字母组合. 下图的手机按键图,就表示了每个数字可以代表的字母. 样例 给定 "23" 返回 [& ...
- LeetCode(17):电话号码的字母组合
Medium! 题目描述: 给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合. 给出数字到字母的映射如下(与电话按键相同).注意 1 不对应任何字母. 示例: 输入:"23& ...
- Leetcode之回溯法专题-17. 电话号码的字母组合(Letter Combinations of a Phone Number)
[Leetcode]17. 电话号码的字母组合(Letter Combinations of a Phone Number) 题目描述: 给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组 ...
随机推荐
- [hdu5379 Mahjong tree]dfs计数
题意:给n个节点的树编号1-n,一个节点唯一对应一种编号,要求编完号的树满足如下性质:所有节点的儿子的编号是连续的,对一棵子树,它包含的所有节点的编号也是连续的.连续的意思是把所有数排序后是一段连续的 ...
- 基于MySQL 的 SQL 优化总结
文章首发于我的个人博客,欢迎访问.https://blog.itzhouq.cn/mysql1 基于MySQL 的 SQL 优化总结 在数据库运维过程中,优化 SQL 是 DBA 团队的日常任务.例行 ...
- 轻量级熔断降级框架 alibaba sentinel 应用
一.简介: wiki:https://github.com/alibaba/Sentinel/wiki 选择: ♥ 开源,成熟(功能完备.实际应用),活跃(功能维护及拓展) ♥ 更轻量:依赖资源少:a ...
- node响应头缓存设置
我把react项目分成4个板块,在路由的顶层 今天在手机上打开react项目的时候,发现平级路由跳转时某一个图片较多的板块图片总是渲染得很慢,这分明是重新发起请求了. 然后我先查一下react-rou ...
- scrapy五大核心组件
scrapy五大核心组件 引擎(Scrapy)用来处理整个系统的数据流处理, 触发事务(框架核心) 调度器(Scheduler)用来接受引擎发过来的请求, 压入队列中, 并在引擎再次请求的时候返回. ...
- PG 更新统计信息
http://blog.chinaunix.net/uid-24774106-id-3802225.html 一.vacuum的效果: 1.1释放,再利用 更新/删除的行所占据的磁盘空间. 第一点的原 ...
- 按图索骥,一些mysql知识点
有事没事多看看 基础知识考察 基础知识,尤其是一些理论知识,例如: MySQL有哪些索引类型,这是个半开放式命题: 从数据结构角度可分为B+树索引.哈希索引.以及不常用的FULLTEXT索引(现在My ...
- HTML中id与name的通俗区别
转自:https://blog.csdn.net/qq_35038153/article/details/70215356 https://zhidao.baidu.com/question/7582 ...
- 51Nod栈
LYK有一个栈,众所周知的是这个数据结构的特性是后进先出的. LYK感觉这样子不太美妙,于是它决定在这个前提下将其改进,也就是说,每次插入元素时,可以在栈顶或者栈底插入,删除元素时,只能在栈顶删除.L ...
- Mysql 查询指令 1
一.查询两个时间字段相减的差值 >>> (TIME_TO_SEC(时间字段一) select bl_no, task_result, carrier_code, task_start ...