Shell函数:递归函数、阶乘和函数库

2024-09-01 22:36

本文主要是介绍Shell函数:递归函数、阶乘和函数库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


文章目录

  • 递归函数
    • 示例1:阶乘计算
    • 示例2:递归列出目录
  • 函数库


递归函数

递归是指函数在其内部调用自身。递归函数常用于解决像阶乘、斐波那契数列等问题。

示例1:阶乘计算

阶乘(Factorial)是数学中的一种运算,表示从1乘以2乘以3…直到某个数n的乘积,记作n!

例如:

  • 4! = 1×2×3×4 = 24 (24是4的阶乘)
  • 6! = 1×2×3×4×5×6 = 720 (720是6的阶乘)
#!/bin/bash
# 定义计算阶乘的函数
fact () {if [ $1 -eq 1 ]  # 如果输入参数等于1,直接返回1thenecho 1elselocal temp=$[$1 - 1]    # 计算当前参数减1local result=$(fact $temp)  # 递归调用函数factecho "$[$1 * $result]"  # 计算并返回当前参数乘以递归结果fi
}read -p "请输入阶乘数:" n
result=$(fact $n)  # 调用函数并存储结果
echo "$result"

流程说明

  • 假如输入 5 。
  • 调用 fact 函数,并将5作为输入参数传递进去。
  • fact 函数内部,判断输入参数是否等于1。由于输入参数为5,所以不等于1。
  • 将输入参数减1,得到4。然后递归调用 fact 函数,并将4作为输入参数传递进去。
  • 依此类推,直到输入参数为1,递归终止,返回结果

示例2:递归列出目录

递归不仅可以用来计算,还可以用于遍历文件目录树。

ls -R * 比较相似。

#!/bin/bash
function list_files {for f in $(ls $1) # 或 `ls $1`doif [ -d "$1/$f" ]   # 如果是目录thenecho "$f"  # 输出目录名list_files "$1/$f"  # 递归调用函数elseecho "$f"  # 输出文件名fidone
}
list_files $1  # 从命令行参数获取起始目录

示例说明:

  • [ -d "$1/$f" ] ,斜杠( / )用于将参数 $1 和变量 $f 连接起来,以构造一个路径,用于检查是否存在指定的目录。例如,如果参数 1 包含 / h o m e / u s e r ,变量 1包含/home/user,变量 1包含/home/user,变量f包含mydir,则路径/home/user/mydir将被构造出来,并用于检查是否存在一个名为mydir的目录。
  • 若为目录,递归调用 list_files 继续列出子目录内容。

函数库

函数库用于将函数定义和可执行脚本代码分离,以便于复用。只包含函数定义的脚本文件称为函数库。

函数库文件 test8.sh:

#!/bin/bash
# 定义加法函数
jiafa () {result=$[$1 + $2]echo $result
}# 定义减法函数
jianfa () {result=$[$1 - $2]echo $result
}# 定义乘法函数
chengfa () {result=$[$1 * $2]echo $result
}# 定义除法函数
chufa () {if [ $2 -ne 0 ]thenresult=$[$1 / $2]echo $resultelseecho "除数不能为0!"fi
}

主脚本文件 test9.sh:

#!/bin/bash
. /opt/jiaoben1/test8.sh  # 引入函数库
read -p "输入第一个参数值:" first
read -p "输入第二个参数值:" second# 调用函数并存储结果
result1=$(jiafa $first $second)
result2=$(jianfa $first $second)
result3=$(chengfa $first $second)
result4=$(chufa $first $second)# 输出结果
echo $result1
echo $result2
echo $result3
echo $result4

执行脚本:

[root@localhost aaa]# chmod +x test9.sh
[root@localhost aaa]# ./test9.sh
输入第一个参数值:20
输入第二个参数值:10
30
10
200
2

这篇关于Shell函数:递归函数、阶乘和函数库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1128240

相关文章

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

uva 10061 How many zero's and how many digits ?(不同进制阶乘末尾几个0)+poj 1401

题意是求在base进制下的 n!的结果有几位数,末尾有几个0。 想起刚开始的时候做的一道10进制下的n阶乘末尾有几个零,以及之前有做过的一道n阶乘的位数。 当时都是在10进制下的。 10进制下的做法是: 1. n阶位数:直接 lg(n!)就是得数的位数。 2. n阶末尾0的个数:由于2 * 5 将会在得数中以0的形式存在,所以计算2或者计算5,由于因子中出现5必然出现2,所以直接一

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

函数式编程思想

我们经常会用到各种各样的编程思想,例如面向过程、面向对象。不过笔者在该博客简单介绍一下函数式编程思想. 如果对函数式编程思想进行概括,就是f(x) = na(x) , y=uf(x)…至于其他的编程思想,可能是y=a(x)+b(x)+c(x)…,也有可能是y=f(x)=f(x)/a + f(x)/b+f(x)/c… 面向过程的指令式编程 面向过程,简单理解就是y=a(x)+b(x)+c(x)

jenkins 插件执行shell命令时,提示“Command not found”处理方法

首先提示找不到“Command not found,可能我们第一反应是查看目标机器是否已支持该命令,不过如果相信能找到这里来的朋友估计遇到的跟我一样,其实目标机器是没有问题的通过一些远程工具执行shell命令是可以执行。奇怪的就是通过jenkinsSSH插件无法执行,经一番折腾各种搜索发现是jenkins没有加载/etc/profile导致。 【解决办法】: 需要在jenkins调用shell脚

利用matlab bar函数绘制较为复杂的柱状图,并在图中进行适当标注

示例代码和结果如下:小疑问:如何自动选择合适的坐标位置对柱状图的数值大小进行标注?😂 clear; close all;x = 1:3;aa=[28.6321521955954 26.2453660695847 21.69102348512086.93747104431360 6.25442246899816 3.342835958564245.51365061796319 4.87

OpenCV结构分析与形状描述符(11)椭圆拟合函数fitEllipse()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C++11 算法描述 围绕一组2D点拟合一个椭圆。 该函数计算出一个椭圆,该椭圆在最小二乘意义上最好地拟合一组2D点。它返回一个内切椭圆的旋转矩形。使用了由[90]描述的第一个算法。开发者应该注意,由于数据点靠近包含的 Mat 元素的边界,返回的椭圆/旋转矩形数据

Unity3D 运动之Move函数和translate

CharacterController.Move 移动 function Move (motion : Vector3) : CollisionFlags Description描述 A more complex move function taking absolute movement deltas. 一个更加复杂的运动函数,每次都绝对运动。 Attempts to

✨机器学习笔记(二)—— 线性回归、代价函数、梯度下降

1️⃣线性回归(linear regression) f w , b ( x ) = w x + b f_{w,b}(x) = wx + b fw,b​(x)=wx+b 🎈A linear regression model predicting house prices: 如图是机器学习通过监督学习运用线性回归模型来预测房价的例子,当房屋大小为1250 f e e t 2 feet^

JavaSE(十三)——函数式编程(Lambda表达式、方法引用、Stream流)

函数式编程 函数式编程 是 Java 8 引入的一个重要特性,它允许开发者以函数作为一等公民(first-class citizens)的方式编程,即函数可以作为参数传递给其他函数,也可以作为返回值。 这极大地提高了代码的可读性、可维护性和复用性。函数式编程的核心概念包括高阶函数、Lambda 表达式、函数式接口、流(Streams)和 Optional 类等。 函数式编程的核心是Lambda