Skip to main content

The Coding Pattern Under LeetCode Recursion Part

Let's go over today about how to write readable recursive code with certain coding pattern. 

Firstly, start with example from leetcode, a command question. 


Given a string containing digits from 2-9 inclusive, 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. Note that 1 does not map to any letters.


Example:

Input: "23"
Output: ["ad", "ae", "af", "bd", "be", "bf", "cd", "ce", "cf"].
The problem is asking to have all combination for give numbers.
Step 1: define the static digital -> Letters



Step 2:  define the recursive method.
Since the leetcode had defined the method already: 
public List<String> letterCombinations(String digits) {

we defined public List<String> letterCombinationsRecursive(List<char[]> letterLists, int[] marks, int deep, List<String> combins)

There will be most time have 4 parameters we defined here

List<char[]> letterLists:  the source data used by code.
int[] marks/boolean[] marks: the mark for each selection.
int deep: how many choice we have done, in this case, how many digital we have mapped to letter.
        The deep here can be replaced with Stack<T> for more generic usage. so we can keep tracking 
        of each step status.

List<String> combins: the final result, for some problem, it is not needed if only need find one match and then return. But for this case, we need list all possible combination. 


Inside the code, the first part will be always check the return condition:
 if(deep == letterLists.size()) {
StringBuilder sb = new StringBuilder();
for(int i = 0; i < marks.length; i ++) {
sb.append(letterLists.get(i)[marks[i]]);
}
combins.add(sb.toString());
return;
}
the second part: recursive + loop + if 
        for this case, loop each letter for digital on processing, then move to next digital recursively. No if needed here since there is no limitation from problem.
        for(int i = 0; i < letterList.length; i ++) {
            marks[deep] = i;
            letterCombinationsRecursionWithPattern(letterLists, marks, deep + 1, combins);
        }
        and the marks is updated and passed the deep + 1 as next level. 

then we are all set.


Most of recursive programing can following the coding pattern above, in summary.
1. define recursive the method(T srcData, int[] marks, int deep, R result)
2. Inside the method:   write down the return condition
3. main body of recusion
    3.1 loop+recursive + if (for a list of choose options, we don't know the length). 
, or just 
    3.2 recursive 1, recursive 2... recursive n + if (for the known choose options, for example, choose or no choose, or move to 4 direction).  


Here is I post the full implements for this problem.


For other more leetcode solution, refer to 
For each of solution, I write down the test case to play with.

Comments

Popular posts from this blog

How to fix "ValueError when trying to compile python module with VC Express"

When I tried to compile the python, I always get compile issue as following: ------------ ... File "C:\Python26\lib\ distutils\msvc9compiler.py ", line 358, in initialize vc_env = query_vcvarsall(VERSION, plat_spec) File "C:\Python26\lib\ distutils\msvc9compiler.py ", line 274, in query_vcvarsall raise ValueError(str(list(result.keys()))) ValueError: [u'path'] --------------------- Python community discussed a lot but no solution: http://bugs.python.org/issue7511 The root cause is because the latest visual studio change the *.bat file a lot especially on 64bit env. The python 2.7 didn't update the path accordingly. Based on the assumption above, the following solution worked for me. To install Visual Studio 2008 Express Edition with all required components: 1. Install Microsoft Visual Studio 2008 Express Edition. The main Visual Studio 2008 Express installer is available from (the C++ installer name is vcsetup.exe): https://ww

How to convert the ResultSet to Stream

Java 8 provided the Stream family and easy operation of it. The way of pipeline usage made the code clear and smart. However, ResultSet is still go with very legacy way to process. Per actual ResultSet usage, it is really helpful if converted as Stream. Here is the simple usage of above: StreamUtils.uncheckedConsumer is required to convert the the SQLException to runtimeException to make the Lamda clear.

How to run odoo(openerp8) in IDE from source on windows

1. install python 2.7 (per openerp8's official doc, python 27 is required.) 2. download get-pip.py from https://bootstrap.pypa.io/get-pip.py , execute the command: python get-pip.py 3. get source of openerp8 from https://github.com/odoo/odoo.git 4. execute the command: pip install -r D:\source_code\odoo\openerp8/requirements.txt . (requirements.txt contains all dependencies. ) The pip will install the python module automatically. However, the real world always bring us the issues because our C++ compile environment is not setup correctly.  we will get the link error when pip try to install psycopg2 (driver to access postgresql db.). Go to  http://www.stickpeople.com/projects/python/win-psycopg/  and choose the compiled binary file directly. For Python-ldap, go to  http://www.lfd.uci.edu/~gohlke/pythonlibs/ 5. Finally, go to http://sourceforge.net/projects/pywin32/files/pywin32 and choose correct version for python-win32service. 6. If you are family with eclipse a lot,