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 
$ 


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

相关推荐

  1. shell_80.Linux函数

    2023-12-08 22:08:04       59 阅读
  2. 函数介绍和实现

    2023-12-08 22:08:04       57 阅读
  3. C语言中函数

    2023-12-08 22:08:04       35 阅读
  4. Python:函数

    2023-12-08 22:08:04       47 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-08 22:08:04       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-08 22:08:04       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-08 22:08:04       82 阅读
  4. Python语言-面向对象

    2023-12-08 22:08:04       91 阅读

热门阅读

  1. postgresql自带指令命令系列一

    2023-12-08 22:08:04       41 阅读
  2. 命令模式-C++实现

    2023-12-08 22:08:04       47 阅读
  3. 不同进程共享变量

    2023-12-08 22:08:04       56 阅读
  4. IntelliJ IDEA安装使用教程#intellij idea

    2023-12-08 22:08:04       62 阅读