• 【JAVA、C++】LeetCode 017 Letter Combinations of a Phone Number


    Given a digit string, return all possible letter combinations that the number could represent.

    A mapping of digit to letters (just like on the telephone buttons) is given below.

    解题思路:

    思路一:

    使用DFS算法,JAVA实现如下:

    	    static String[] alpha = new String[] {
    	    		" ","1", "abc", "def","ghi", "jkl", "mno","pqrs", "tuv", "wxyz"
    	    };
    	    static StringBuilder sb = new StringBuilder();  
    	    static  void dfs(List<String> list, String digits, int cur) {
    	        if (cur >= digits.length())
    	            list.add(sb.toString());
    	        else {
    	            for (int i = 0; i < alpha[digits.charAt(cur) - '0'].length(); i++) {
    	                sb.append(alpha[digits.charAt(cur) - '0'].charAt(i));
    	                dfs(list, digits, cur + 1);
    	                sb.deleteCharAt(sb.length() - 1);
    	            }
    	        }
    	    }
    	   static public List<String> letterCombinations(String digits) {
    	        List<String> list = new ArrayList<String>();
    	        if (digits.length()==0)
    	          return list;
    	        dfs(list, digits, 0);
    	        return list;
    	    }
    

     C++:

     1 class Solution {
     2 public:
     3     const string alpha[10] = {" ","1", "abc", "def","ghi", "jkl", "mno","pqrs", "tuv", "wxyz"};
     4     void dfs(vector<string> &list, string &digits, int cur,string sb) {
     5         if (cur >= digits.length())
     6             list.push_back(sb);
     7         else {
     8             for (char a : alpha[digits[cur] - '0']) {
     9                 sb.push_back(a);
    10                 dfs(list, digits, cur + 1,sb);
    11                 sb.pop_back();
    12             }
    13         }
    14     }
    15     vector<string> letterCombinations(string digits) {
    16         vector<string> list;
    17         if (digits.length() == 0)
    18             return list;
    19         dfs(list, digits, 0,"");
    20         return list;
    21     }
    22 };

    思路二:

    凡是用到递归的地方都能用循环解决,因此可以用循环算法,JAVA实现如下:

    static public List<String> letterCombinations(String digits) {   
    	        List<String> list = new ArrayList<String>();
    	        String[] alpha = new String[] {
    		    		" ","1", "abc", "def","ghi", "jkl", "mno","pqrs", "tuv", "wxyz"
    		    };
    	        if (digits.length()==0)
    	        	return list;
    	        int[] number = new int[digits.length()];//存储每次遍历字符位置
    	        int index = 0;
    	        while(index>=0) {  
    	            StringBuilder sb = new StringBuilder();
    	            for(int i=0; i<digits.length(); i++) 
    	                sb.append(alpha[digits.charAt(i)-'0'].charAt(number[i]));  
    	            list.add(sb.toString());  
    	            // 每回合需要重置index到末尾
    	            index = digits.length()-1;  
    	            while(index>=0) {  
    	                if( number[index] < (alpha[digits.charAt(index)-'0'].length()-1) ) {  
    	                    number[index]++;  
    	                    break;  
    	                } else {  
    	                    number[index] = 0;  
    	                    index--;  
    	                }  
    	            }  
    	        }  
    	        return list;
    	    }
    
  • 相关阅读:
    HTML Rendering Error
    PyCharm将选中的内容加上引号
    Scrapy中的Request和日志分析
    PyCharm关闭按两次Shift进入搜索框的功能
    博客园更换模板的链接
    Scrapy的Spider类和CrawlSpider类
    Scrapy安装和简单使用
    计算π的近似值
    Python用pip安装第三方库时换源下载
    网页解析 -- bs4 和 xpath 的简单使用
  • 原文地址:https://www.cnblogs.com/tonyluis/p/4471607.html
Copyright © 2020-2023  润新知