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 
$ 


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

  • 9
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

微辣已是极限

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值