Joke Collection Website - Mood Talk - What is the "iteration method" in mathematics? What's the use?
What is the "iteration method" in mathematics? What's the use?
Iterative algorithm is the basic method to solve problems with computers. It makes use of the characteristics of computer's fast operation speed and suitable for repeated operation, so that the computer can repeatedly execute a set of instructions (or some steps), and every time this set of instructions (or these steps) is executed, the new value of a variable is deduced from its original value.
Using iterative algorithm to solve the problem, we need to do the following three aspects:
First, determine the iteration variables. Among the problems that can be solved by iterative algorithm, at least one variable directly or indirectly deduces a new value from the old value, and this variable is an iterative variable.
Second, establish an iterative relationship. The so-called iterative relationship refers to how to deduce the formula (or relationship) of the next value from the previous value of a variable. The establishment of iterative relationship is the key to solve iterative problems, which can usually be done by recursion or reverse derivation.
Third, control the iterative process. When does the iterative process end? This is a problem that must be considered when writing iterative programs. The iterative process cannot be repeated endlessly. The control of iterative process can usually be divided into two situations: one is that the required number of iterations is a certain value, which can be calculated; The other is that the number of iterations required cannot be determined. For the former case, a fixed number of loops can be constructed to control the iterative process; In the latter case, it is necessary to further analyze the conditions for ending the iterative process.
A new breed of rabbit was introduced to a farm. This kind of rabbit will give birth to a new rabbit every month from the second month after birth, and the new rabbit will reproduce in the same way. If all the rabbits didn't die, how many rabbits were there on this farm in1February?
Analysis: This is a typical recursive problem. We might as well assume that the number of rabbits in the first month 1 is u 1, the number of rabbits in the second month is u 2, and the number of rabbits in the third month is u 3 ... According to the meaning of the question, "this kind of rabbit gives birth to a new rabbit every month from the month after birth".
u 1 = 1,u 2 = u 1 + u 1 × 1 = 2,u 3 = u 2 + u 2 × 1 = 4,…
According to this rule, the following recursive formulas can be summarized:
u n = u n - 1 × 2 (n ≥ 2)
Corresponding to u n and U n- 1, two iterative variables y and x are defined, and the above recursive formula can be transformed into the following iterative relationship:
y=x*2
x=y
Let the computer repeat this iterative relationship 1 1 times, and you can calculate the number of rabbits in1February. The reference procedure is as follows:
cls
x= 1
For i=2 to 12
y=x*2
x=y
Next, I
Print y
end
Example 2: Amoeba reproduce by simple division, each division takes 3 minutes. Put several amoeba protozoa into a container filled with nutritious ginseng liquid, and the container will be full of amoeba protozoa after 45 minutes. It is known that this container can hold 2 20 amoeba. How many amoebas were put in the container at first? Please program.
Analysis: According to the meaning of the question, the amoeba divides every 3 minutes, so it takes 45/3= 15 times to put the amoeba into the container at first and fill it up after 45 minutes. However, "the container can hold 2 20 amoebas at most", that is, the number of amoebas obtained after dividing by 15 times is 2 20. The topic requires us to calculate the number of amoebas before division. We might as well use the backward method to derive the number before 15 (that is, the number after 14) from 2 20 after 15 is divided, and then further derive the number after 13 is divided by 12. ...
Let the number before the 1 split be x 0, the number after the 1 split be x1,the number after the second split be x 2, ... 15, and the number after the split is x 15, then there are
x 14 =x 15 /2、x 13 =x 14 /2、…… x n- 1 =x n /2 (n ≥ 1)
Because the number after the15th split is known, if the iterative variable is defined as x, the above backward formula can be transformed into the following iterative formula:
X = x/2 (the initial value of x is the number 2 20 after the 5th split/kloc-0).
By repeating this iterative formula 15 times, the number of amoeba before 1 division can be calculated. Because the number of iterations required is a certain value, we can use a fixed number of cycles to control the iterative process. The reference procedure is as follows:
cls
x=2^20
For i= 1 to 15.
x=x/2
Next, I
Print x
end
Example 3: Verify the Valley Angle Conjecture. When Japanese mathematician Sadakazu Tanigaki studied natural numbers, he found a strange phenomenon: for any natural number n, if n is an even number, it is divided by 2; If n is odd, multiply it by 3 and add 1. After a finite number of operations, you can always get the natural number 1. People call this discovery of Tanaki Zuo Shi "Tanaki conjecture".
Requirements: Write a program, input a natural number N through the keyboard, and print out the whole process that N becomes a natural number 1 after a limited number of operations.
Analysis: define the iterative variable as n, and according to the content of the valley angle conjecture, we can get the iterative relationship in two cases: when n is even, n = n/2; When n is odd, n=n*3+ 1. Described in QBASIC language is:
If n is an even number, then
n=n/2
other
n=n*3+ 1
If ... it will be over.
This is an iterative process that needs to be repeated by the computer. How many times does this iterative process need to be repeated to make the iterative variable n finally become a natural number of 1, which is beyond our calculation. Therefore, it is necessary to further determine the conditions for ending the iterative process. After careful analysis of the requirements of the problem, it is not difficult to see that for any given natural number n, the natural number 1 can be obtained after a limited number of operations, and the verification work has been completed. Therefore, the condition for ending the iterative process can be defined as: n= 1. The reference procedure is as follows:
cls
Enter "Please enter n ="; n
Until n= 1
If n modulo 2=0, then
Rem If n is an even number, call the iterative formula n=n/2.
n=n/2
Print''; n;
other
n=n*3+ 1
Print''; n;
If ... it will be over.
ring
end
iterative method
Iterative method is a commonly used algorithm design method to find the approximate root of an equation or equation. Let the equation be f(x)=0, and deduce the equivalent form x=g(x) by some mathematical method, and then follow the following steps:
(1) Select the approximate root of an equation and assign it to the variable x0;
(2) Save the value of x0 in the variable x 1, then calculate g(x 1) and save the result in the variable x0;
(3) When the absolute value of the difference between x0 and x 1 is less than the specified accuracy requirement, repeat the calculation in step (2).
If the equation has roots and the approximate root sequence calculated by the above method converges, it is considered that x0 calculated by the above method is the root of the equation. The above algorithm is expressed in the form of C program as follows:
Iterative algorithm for finding the root of equation
{x0= initial approximate root;
Do {
x 1 = x0;
x0 = g(x 1); /* Calculate a new approximate root according to a specific equation */
} while ( fabs(x0-x 1)>ε);
Printf ("The approximate root of the equation is %f\n", x0);
}
Iterative algorithms are also often used to find the roots of equations, so that
X=(x0,x 1,…,xn- 1)
Let the equation be:
xi=gi(X) (I=0, 1,…,n- 1)
The iterative algorithm for finding the root of the equation can be described as follows:
Iterative algorithm for finding the root of equation
{ for(I = 0; I
X= initial approximate root;
Do {
for(I = 0; I
y = x;
for(I = 0; I
X = gi(X);
for(δ= 0.0,I = 0; I
if (fabs(y-x)>delta)delta = fabs(y-x);
} while(delta & gt; ε);
for(I = 0; I
Printf ("The approximate root of variable x[%d] is %f", i, x);
printf(" \ n ");
}
When using iterative method to find the root, we should pay attention to the following two possible situations:
(1) If the equation has no solution, the approximate root sequence obtained by the algorithm will not converge, and the iterative process will become an infinite loop. Therefore, before using iterative algorithm, it is necessary to check whether the equation has a solution and limit the number of iterations in the program.
(2) Although the equation has a solution, improper selection of iteration formula or unreasonable selection of initial approximate root will also lead to iteration failure.
recursion
Recursion is a powerful tool for designing and describing algorithms. Because it is often used to describe complex algorithms, we should discuss other algorithm design methods before introducing them.
Algorithms that can be described recursively usually have the following characteristics: in order to solve the problem of scale n, try to decompose it into smaller problems, and then conveniently construct the solutions of large problems from the solutions of these small problems. These smaller problems can also be decomposed into smaller problems by the same decomposition and synthesis method, and the solutions of larger problems can be constructed from the solutions of these smaller problems. Especially, when the scale N= 1, the solution can be obtained directly.
The problem is to write and calculate the nth function fib(n) of Fibonacci sequence.
Fibonacci sequence is: 0, 1, 1, 2, 3, ..., that is:
fib(0)= 0;
fib( 1)= 1;
Fib(n)=fib(n- 1)+fib(n-2) (when n >; 1).
Written as recursive functions are:
Intermediate fiber (intermediate fiber)
{if (n==0) returns 0;
If (n== 1) returns1;
If (n> 1) returns to fiber (n- 1)+ fiber (n-2);
}
The implementation process of recursive algorithm is divided into two stages: recursion and regression. In the recursive stage, the solution of a more complex problem (scale n) is pushed to the solution of a simpler problem (scale less than n) than the original problem. For example, in the above example, solve fib(n) and deduce fib(n- 1) and fib(n-2). That is to say, in order to calculate fib(n- 1) and fib(n- 2), fib(n- 1) and fib(n-2) must be calculated first, and fib(n-3) and fib(n-4) must be calculated first. And so on, until fib( 1) and fib(0) are calculated, the results of 1 and 0 can be obtained immediately. In the recursion stage, there must be circumstances to terminate recursion. For example, in the function fib, when n is 1 and 0.
In the regression stage, when the solution of the simplest case is obtained, it returns to the solution of a slightly complicated problem step by step, for example, after obtaining fib( 1) and fib(0), it returns the result of fib(2), ..., after obtaining fib(n- 1) and fib(n-2).
When writing a recursive function, it should be noted that the knowledge of local variables and parameters in the function is limited to the current calling layer. When it is pushed to the Simple Problem layer, the parameters and local variables in the original layer are hidden. In a series of simple problem layers, they all have their own parameters and local variables.
Because recursion causes a series of function calls, and there may be a series of repeated calculations, the execution efficiency of recursive algorithm is relatively low. When recursive algorithm can be easily converted into recursive algorithm, programs are usually written according to recursive algorithm. For example, in the above example, the function fib(n) of the nth term of Fibonacci sequence is calculated by recursive algorithm, that is, the next term is calculated one by one from the first two terms of Fibonacci sequence until the required nth term is calculated.
Problem combination problem
Problem description: Find all combinations of R numbers from natural number 1, 2, ... For example, all combinations of n=5 and r=3 are: (1) 5,4,3 (2) 5,4,2 (3) 5,4 and1.
(4)5、3、2 (5)5、3、 1 (6)5、2、 1
(7)4、3、2 (8)4、3、 1 (9)4、2、 1
( 10)3、2、 1
By analyzing the listed 10 combinations, we can use this recursive idea to consider the algorithm for finding the combination function. Let the function void comb(int m, int k) be used to select from the natural number 1, 2, ... When the first number of the combination is selected, the following number is the combination of k- 1 numbers among the remaining m- 1 numbers. This transforms the combination problem of finding k from the number of m into the combination problem of finding k- 1 from the number of m- 1. Let the function introduce the working array a[] to store the solved combination number, and the appointed function puts the first number of the determined combination of k numbers into a[k]. When solving a combination, output a combination in []. The first number can be m, m- 1, ... After the function puts the first number of the determined combination into the array, there are two possible choices. Because the remaining elements of the combination have not been removed, it will be determined recursively. Or the combination is output because all elements of the combination have been determined. See the function comb in the following program for details.
procedure
# Including
# Define MAXN 100
int a[MAXN];
Empty comb (integer m, integer k)
{ int i,j;
for(I = m; I>= k;; I-)
{ a[k]= I;
if(k & gt; 1)
Comb (i- 1, k-1);
other
{ for(j = a[0]; j & gt0; j -)
printf("%4d ",a[j]);
printf(" \ n ");
}
}
}
void main()
{ a[0]= 3;
Combs (5, 3);
}
knapsack problem
Problem description: There are n projects with different values and weights. Find the selection scheme of the middle sub-projects of these n projects, so that the total weight of the selected projects does not exceed the specified limit weight, but the sum of the values of the selected projects is the largest.
Let the weight of n term be w0, w 1, …, wn- 1, and the value of n term be v0, v 1, …, vn- 1. The selection scheme of recursive search items is adopted. Suppose there are many alternatives, the scheme with the largest total value is saved in the array option[], and the total value of this scheme is saved in the variable maxv. At present, a new scheme is being investigated, and its project selection is saved in the array cop[]. Assuming that the current scheme has considered item i- 1, item I should be considered now; The sum of the project weights already included in the current scheme is TW; So far, if other projects can be selected, the expected value of the total value that this scheme can achieve is TV. When tv is introduced into the algorithm, once the expected value of the total value of the current scheme is less than the total value of the previous scheme, it becomes meaningless to continue to investigate the current scheme, so the current scheme should be terminated and the next scheme should be investigated immediately. Because when the total value of the scheme is not greater than maxv, the scheme will not be checked again, which also ensures that the scheme found after the function will be better than the previous scheme.
There are two possibilities for the choice of article I:
(1) Considering that the first item is selected, this possibility is feasible only if it does not exceed the total weight limit of the scheme. After the selection is completed, continue to recursively consider the selection of other items.
(2) Considering that item I is not selected, this possibility is only available when it is possible to find a more valuable scheme without item I. ..
Write the recursive algorithm according to the above ideas as follows:
Try (the first item, the sum of the weights reached by the current selection, and the possible total value tv of the scheme)
{/* Consider the possibility of the first item being included in the current scheme */
If (including the first item is acceptable)
{Include project i in the current scheme;
If (I)
Try (i+ 1, tw+ weight of article I, TV);
other
/* Another complete scheme, because it is better than the previous scheme and the best scheme */
Save the current scheme as a temporary optimal scheme;
Restore the state not included in project I;
}
/* Consider the possibility that the first item is not included in the current scheme */
If (excluding the first item, only men can be considered)
If (I)
Try(i+ 1, tw, tv- the value of item I);
other
/* Another complete scheme, because it is better than the previous scheme and the best scheme */
Save the current scheme as a temporary optimal scheme;
}
In order to understand the above algorithm, several examples are given below. There are four items, and their weights and values are shown in the table:
Item 0 1 2 3
Weight 5 3 2 1
Value 4 4 3 1
And set the limit weight to 7. Then according to the above algorithm, the following figure is the solution process. As can be seen from the figure, once a solution is found, the algorithm will further find a better one. If it can be determined that a search branch will not find a better solution, the algorithm will not continue to search in the branch, but immediately terminate the branch and investigate the next branch.
The functions and programs written according to the above algorithm are as follows:
procedure
# Including
# Definition number 100
Double limitW, totV, maxV
int option[N],COP[N];
Structure {double weight;
Double value;
} a[N];
int n;
void find(int i,double tw,double tv)
{ int k;
/* Consider the possibility of the first item being included in the existing scheme */
if(tw+a . weight & lt; =limitW)
{ COP = 1;
If (I)
other
{ for(k = 0; k
option[k]= COP[k];
Maxv = TV;
}
COP = 0;
}
/* Consider the possibility that the first item is not included in the current scheme */
if(TV-a . value & gt; maxV)
If (I)
other
{ for(k = 0; k
option[k]= COP[k];
maxv = TV-a . value;
}
}
void main()
{ int k;
Double w, v;
Printf ("Enter the number of items \ n");
scanf(("%d ",& ampn);
Printf ("Enter the weight and value of each item \ n");
for (totv=0.0,k = 0; k
{ scanf("% 1f% 1f ",& ampw & amp; 5);
a[k]。 Weight = w;;
a[k]。 Value = v;;
totV+= V;
}
Printf ("Enter limit weight \ n");
scanf("% 1f ",& amplimitV);
maxv = 0.0
for(k = 0; k find(0,0.0,totV);
for(k = 0; k
if (option[k]) printf("%4d ",k+ 1);
Printf ("\ nTotal value is% .2f \ n", maxv);
}
As a contrast, we will consider the non-recursive program solution with the same problem-solving idea. In order to improve the speed of finding the solution, the program does not simply generate all the candidate solutions one by one, but forms a candidate solution worthy of further consideration from the influence of each term on the candidate solution. By examining each item in turn, a candidate solution is formed. There are several situations in the investigation of the first article: when the article is included in the candidate scheme and still meets the total weight limit of the scheme, it should continue to be considered if it is included in the candidate scheme; On the contrary, the project should not be included in the candidate solution currently being formed. Similarly, only when an item is not included in the candidate solution, and it is possible to find a better candidate solution than the current temporary optimal solution, will it be considered that the item is not included in the candidate solution; On the other hand, the scheme that the project is not included in the current candidate scheme should not be further considered. For any scheme worthy of further consideration, the program will further consider the next item.
procedure
# Including
# Definition number 100
Double restriction w;
int COP[N];
Structural elements {double weight;
Double value;
} a[N];
int k,n;
struct { int
Double tw;
Double TV;
} twv[N];
The next one is invalid (int i, double tw, double tv)
{ twv。 = 1;
twv.tw = tw
twv.tv = tv
}
Double search (struct ele *a, int n)
{ int i,k,f;
Double maxv, tw, tv, totv
maxv = 0;
for (totv=0.0,k = 0; k
totv+=a[k]。 Value;
Next (0,0.0, totv);
I = 0;
while(I & gt; =0)
{ f=twv。 ;
tw = twv . tw;
TV = twv . TV;
Switch (f)
{Case 1: twv. ++;
if(tw+a . weight & lt; =limitW)
If (I)
{Next (i+ 1, tw+a.weight, TV);
i++;
}
other
{ maxv = tv
for(k = 0; k
cop[k]=twv[k]。 ! =0;
}
Break;
Case 0: I-;
Break;
Default: twv. =0;
if(TV-a . value & gt; maxv)
If (I)
{ next(i+ 1,tw,TV-a . value);
i++;
}
other
{ maxv = TV-a . value;
for(k = 0; k
cop[k]=twv[k]。 ! =0;
}
Break;
}
}
Return maxv
}
void main()
{ double maxv
Printf ("Enter the number of items \ n");
scanf(("%d ",& ampn);
Printf ("Enter limit weight \ n");
scanf("% 1f ",& amplimitW);
Printf ("Enter the weight and value of each item \ n");
for(k = 0; k
scanf("% 1f% 1f ",& ampa[k]。 Weight & ampa[k]. Value);
maxv=find(a,n);
Printf ("\ nThe selected item is \ n");
for(k = 0; k
if (option[k]) printf("%4d ",k+ 1);
Printf ("\ nTotal value is% .2f \ n", maxv);
}
Basic concepts and characteristics of recursion
The programming skill of program calling itself is called recursion.
A procedure or function calls its own method directly or indirectly in its definition or description. It usually turns a big and complicated problem into a small problem similar to the original one to solve. Recursive strategy can describe the repeated calculation in the process of solving problems with few programs, which greatly reduces the code amount of programs. The ability of recursion lies in defining an infinite set of objects with finite statements. Programs written with recursive ideas are often very concise and easy to understand.
Generally speaking, recursion requires boundary conditions, recursive forward segments and recursive return segments. When the boundary conditions are not met, recursively advance; When the boundary condition is satisfied, it returns recursively.
note:
(1) Recursion is to call itself in a procedure or function;
(2) When using the incremental reduction strategy, there must be a clear recursive ending condition, which is called recursive exit.
- Previous article:Which areas in Shenzhen are more interesting?
- Next article:Tell me about it.
- Related articles
- Persuasion theory
- Talk about the children's first day of school.
- Ancient wars were easy to win with fewer?
- Words about retaining love
- Sweet words of drinking
- What does a person say when traveling in a circle of friends?
- Thank you for the humor of your son's gift.
- Love omits talking about emotions.
- People often give their worst temper to the people closest to them.
- How do you describe someone who is dishonest?