: Method that solves the problem by calling the algorithms (or function) back. A suitable method for circular definition.
Divide-and-conquer
: Divide the problem into a set of sub problems. recursively breaks down a problem into two or more sub-problems of the same or related type, until these become simple enough to be solved directly.
tail recursion
: easily implemented using iteration
ex) return n*factorial (n-1);
head recursion
: difficult to implement using iteration
ex) return factorial(n-1) * n;
multi recursion
: difficult to implement using iteration
ex)
function(A, n)
{
//Recursive call of 2.
function(A, n-1)
function(A, n-1)
}
Recursion
: using recursive calls
pros - Good choice for recursive problems (easy to implement)
cons - overhead of function calls -> usually slower execution time
Iteration
: using 'for' or 'while' loop
pros - fast execution time
cons - programming can be often vety difficult for recursive problems
Then, what is best strategy?
-> It depends on problems.
int factorial_recur(int n) {
if (n <= 1) return 1;
else return n * factorial(n - 1);
}
T(N) = T(N-1) + 1 --> Time Complexity : O(N)
int factorial_iter(int n) {
int mul = 1;
for (int i = n; i >= 1; i--) {
mul *= n; // n* (n-1) ... 2*1 ;
}
return mul ;
}
Time Complexity : O(N)
: Let's find n-squared value of x :x^n
double power_iter(double x, int n) { //x^n
int i;
double r = 1.0;
for (i = 0; i < n; i++) {
r = r * x;
}
return r;
}
Time Complexity : O(N)
double power_recur(double x, int n) {
if (n == 0) return 1;
else if ((n % 2) == 0)
return power(x * x, n / 2);
else
return x * power(x * x, n-1/ 2);
}
Time Complexity : T(N) = T(2/N) +C -> O(logN)
iteration is not good choice😥
int fib_recur(int n) {
if (n == 0) return 0;
if (n == 1) return 1;
return fib_recur(n - 1) + fib_recur(n - 2);
}
Time Complexity : T(N) < 2^(N-1) -> O(2^N)
why ? for fib(n), maximum depth of tree is n-1.
and tree must be not filled with leaf node fully.
: to get fib(n), calculating one by one by one from the first two terms .
int fib_iter(int n) {
int temp, current = 1, last = 0; //the first two terms of Fibonacci sequence.
if (n < 2) return n;
else {
for (int i = 1; i < n; i++) {
temp = current; //keep the last value.
current = last + current ; //Renewal Nth term
last = temp; //Save it for the next calculation.
}
}
return current;
}
Time Complexity : O(N)
: move n disc stacked on rod A to rod C.
Divide and conquer
void hanoi_tower(int n, char from, char tmp, char to)
{
if (n == 1) printf("Move 1 disc from % c to % c.\n", from, to);
else {
hanoi_tower(n - 1, from, to, tmp);
printf("Move disc % d from % c to % c.\n", n, from, to);
hanoi_tower(n - 1, tmp, from, to);
}
}
Time Complexity : T(N) = 2T(N-1)+1 = 2^N -1 -> O(2^N)
: when a array of ordered numbers is given, find an index k where ak=b.
int search_iter(A, b)
for i=1 to n
if(A[i] == b)
k=i;
return k
Time Complexity : O(N)
int search_recur(A, b, start, end)
if(start>end) return -1;
int median = (start+end)/2;
if(A[median]<b)
search_recur(A, b, median, end);
else if(A[median]>b)
search_recur(A, b, start, median);
else
return median;
Time Complexity : T(N)=t(N/2)+C -> O(logN)
📚
🧶
🎯⚒🧬⚔🕯🔎💳📂🎫♦⚖🛢
⚙📖📕📗📘✏✒🖋🖊🖌🖍📝📌🗂📎