Citation: http://blog.csdn.net/feixiaoxing/article/details/6838362
In fact, programming friends know that no matter what language you learn, loops and recursion are two things that must be learned. Of course, if the loop is good to understand a bit, then recursion is not that simple. We used to be secretive about recursion, but what I want to tell you is that recursion isn't really that scary. The so-called recursion is the function itself calls itself, the loop is essentially a recursive.
1) summation recursive function
We can give an example of a loop, as we said earlier, if you write a sum function of 1 to n, you might write:
int calculate (int m) { int0; if (M <0) return -1; for (int0; index <= m; index++) + = index ; return count;}
The above is just a demonstration. Let's see if recursion should be written.
int calculate (int m) { if0) return0 ; Else return calculate (M-1) + m;}
What's the difference between the two pieces of code?
(1) The first paragraph of code from 0, began to calculate, from 0 to M gradually calculated; the second code is calculated from 10, gradually to 0 after this time, so that the same can achieve the effect of the calculation
(2) The first paragraph of the code does not need to repeat the stack operation, the second paragraph needs to repeat the function operation, of course, this is the nature of recursion
(3) The first paragraph of code is longer, the second section of the code is relatively short
2) Finding recursive functions
You might say that the code is a bit special. If you are looking for a function of a class, is it possible to modify it into a recursive function?
intFindintArray[],intLengthintvalue) { intindex =0; if(NULL = = Array | |0==length)return-1; for(; index < length; index++) { if(Value = =Array[index])returnindex; } return-1;}
You might say that this code might be modified to code like this:
int_find (intIndexintArray[],intLengthintvalue) { if(Index = =length)return-1; if(Value = =Array[index])returnindex; return_find (Index +1, array, length, value);}intFindintArray[],intLengthintvalue) { if(NULL = = Array | | length = =0) return-1; return_find (0, array, length, value);}
3) pointer variable traversal
Structure pointers are the traversal structures we like, just imagine if there is a data structure defined below:
struct _node{ int data; struct _node* next;} NODE;
So, what do we do when we need to print all the data in a node link? You can think about it first and see if we write the code right.
void Print (const node* pnode) { if(NULL = = pnode )return ; while (pnode) { printf ("%d\n", pnode->data); = Pnode->next; }}
Then if you change to recursion, it's simpler:
void Print (const node* pnode) { if(NULL = = pnode )return ; Else printf ("%d\n", pnode->data); Print (Pnode-next);}
In fact, write so much, just want to share my personal point of view: The loop is a special recursion, only the recursion and the stack is equivalent. All of the recursive code can be written in the form of a stack, the following blog we will discuss the stack and recursive relationship. To write well, you have to master the stack.
"Trailer: The following blog introduces stacks and recursion"
Data structure and algorithm learning two, loops and recursion