shell_80.Linux函数的递归

函数递归
局部函数变量的一个特性是自成体系(self-containment)。
除了获取函数参数,自成体系的函数不需要使用任何外部资源。
递归算法的经典例子是计算阶乘。一个数的阶乘是该数之前的所有数乘以该数的值。因此
要计算 5 的阶乘,可以执行下列算式:

5! = 1 * 2 * 3 * 4 * 5 = 120 


使用递归,这一算法可以简化为以下形式:

x! = x * (x-1)! 


也就是说,x 的阶乘等于 x 乘以 x-1 的阶乘。这可以用简单的递归脚本表达为以下形式:

function factorial { 
 if [ $1 -eq 1 ] 
 then 
 echo 1 
 else 
 local temp=$[ $1 - 1 ] 
 local result=`factorial $temp` 
 echo $[ $result * $1 ] 
 fi 
} 


阶乘函数用其自身计算阶乘的值:

$ cat test13 
#!/bin/bash 
# using recursion 
function factorial { 
    if [ $1 -eq 1 ] 
    then 
        echo 1 
    else 
        local temp=$[ $1 - 1 ] 
        local result=$(factorial $temp) 
        echo $[ $result * $1 ] 
    fi 
} 
read -p "Enter value: " value 
result=$(factorial $value) 
echo "The factorial of $value is: $result" 
$ 
$ ./test13 
Enter value: 5 
The factorial of 5 is: 120 
$ 


阶乘函数并不难。创建了这样的函数后,你甚至想把它用在其他的脚本中。下面来看看如何
有效地利用函数。

你可能感兴趣的:(linux,运维,服务器)