免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3145 | 回复: 5
打印 上一主题 下一主题

递归中使用全局变量(ABS例子) [复制链接]

论坛徽章:
1
辰龙
日期:2014-05-22 11:38:58
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-04-07 10:25 |只看该作者 |倒序浏览
  1. #!/bin/bash

  2. MINIDX=2 # If idx is less than 2, then Fibo(idx) = idx.

  3. Fibonacci ()
  4. {
  5.         idx=$1 # Doesn't need to be local. Why not?

  6.         if [ "$idx" -lt "$MINIDX" ]
  7.         then
  8.                 echo "$idx" # First two terms are 0 1 ... see above.
  9.         else
  10.                 (( --idx )) # j-1
  11.                 term1=$( Fibonacci $idx ) # Fibo(j-1)
  12.                 (( --idx )) # j-2
  13.                 term2=$( Fibonacci $idx ) # Fibo(j-2)
  14.                 echo $(( term1 + term2 ))
  15.         fi
  16. }

  17. FIBO=$(Fibonacci $1)
  18. echo -n "$FIBO "

  19. exit 0
复制代码
这个ABS上递归求斐波那契数列的一段代码,不明白为什么idx用全局变量也行

论坛徽章:
1
辰龙
日期:2014-05-22 11:38:58
2 [报告]
发表于 2012-04-07 10:38 |只看该作者
在ABS上翻到这句话
Command substitution invokes a subshell.

应该是这个原因吧
谁能解释下

论坛徽章:
0
3 [报告]
发表于 2012-04-07 11:08 |只看该作者
本帖最后由 crulat 于 2012-04-07 11:12 编辑
  1. Fibonacci(){ m=${1}; n=m; { { (( ${!n} == 1 )) && echo 0; } || { (( ${!n} == 2 )) && echo 1; }; } || echo $(($(Fibonacci $((${!n}-1)))+$(Fibonacci $((${!n}-2))))); }; Fibonacci ${1}
复制代码
or

  1. Fibonacci()
  2. {
  3.        m=${1}
  4.        n=m
  5.        {
  6.           {
  7.                   (( ${!n} == 1 )) && echo 0
  8.           } || {
  9.                   (( ${!n} == 2 )) && echo 1
  10.                }
  11.           } || {
  12.                    echo $(($(Fibonacci $((${!n}-1)))+$(Fibonacci $((${!n}-2)))))
  13.                }
  14. }

  15. Fibonacci ${1}
复制代码

论坛徽章:
0
4 [报告]
发表于 2012-04-07 15:51 |只看该作者
回复 2# winway1988


  c语言的函数也不会用全局变量啊.这不是很正常么?
你有什么不理解的?

论坛徽章:
1
辰龙
日期:2014-05-22 11:38:58
5 [报告]
发表于 2012-04-07 16:35 |只看该作者
回复 4# mpstat


   
c语言的函数也不会用全局变量啊.

对呀,他要用局部变量,我就理解了,但是他用的是全局变量
idx=$1 # Doesn't need to be local. Why not?

我理解是命令替换的subshell引起的,subshell里的idx改变不会影响其父进程,还是相当于idx是一个局部变量了,不知道理解的对不对?

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
6 [报告]
发表于 2012-04-07 17:21 |只看该作者
因为每次调用函数时的$1是变化的
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP