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

相关文章

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

Java function函数式接口的使用方法与实例

《Javafunction函数式接口的使用方法与实例》:本文主要介绍Javafunction函数式接口的使用方法与实例,函数式接口如一支未完成的诗篇,用Lambda表达式作韵脚,将代码的机械美感... 目录引言-当代码遇见诗性一、函数式接口的生物学解构1.1 函数式接口的基因密码1.2 六大核心接口的形态学

Linux中shell解析脚本的通配符、元字符、转义符说明

《Linux中shell解析脚本的通配符、元字符、转义符说明》:本文主要介绍shell通配符、元字符、转义符以及shell解析脚本的过程,通配符用于路径扩展,元字符用于多命令分割,转义符用于将特殊... 目录一、linux shell通配符(wildcard)二、shell元字符(特殊字符 Meta)三、s

Python实现阶乘的四种写法

《Python实现阶乘的四种写法》本文主要介绍了Python实现阶乘的六种写法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录第一种:推导式+循环遍历列表内每个元素相乘第二种:调用functools模块reduce的php累计

shell脚本快速检查192.168.1网段ip是否在用的方法

《shell脚本快速检查192.168.1网段ip是否在用的方法》该Shell脚本通过并发ping命令检查192.168.1网段中哪些IP地址正在使用,脚本定义了网络段、超时时间和并行扫描数量,并使用... 目录脚本:检查 192.168.1 网段 IP 是否在用脚本说明使用方法示例输出优化建议总结检查 1

Oracle的to_date()函数详解

《Oracle的to_date()函数详解》Oracle的to_date()函数用于日期格式转换,需要注意Oracle中不区分大小写的MM和mm格式代码,应使用mi代替分钟,此外,Oracle还支持毫... 目录oracle的to_date()函数一.在使用Oracle的to_date函数来做日期转换二.日

C++11的函数包装器std::function使用示例

《C++11的函数包装器std::function使用示例》C++11引入的std::function是最常用的函数包装器,它可以存储任何可调用对象并提供统一的调用接口,以下是关于函数包装器的详细讲解... 目录一、std::function 的基本用法1. 基本语法二、如何使用 std::function

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>