公告:本站正式转型为非交互式静态网站!
转型:本站将通过笔记和博客的形式继续为大家服务,关于 Mathematica 问答服务请移步至QQ群:365716997
联系:如有问题请联系QQ群管理员,或发送邮件至:lixuan.xyz@qq.com。
感谢:最后非常感谢大家多年来的支持与帮助!
参考《互联网跟帖评论服务管理规定》《中华人民共和国网络安全法》《网络信息内容生态治理规定》《互联网用户账号信息管理规定》

—— 2022-11-27

欢迎来到 Mathematica 问答社区

提问时请贴上文本代码

语法高亮:在编辑器中点击

被禁止的话题:广告破解

请阅读:《提问的智慧》

备用域名:mma.ooo

支持LaTex数学公式
行内公式标识符:\$ 或“$\backslash ($”+“$\backslash )$”,
行间公式标识符:\$\$ 或 “$\backslash [$”+“$\backslash ]$”

社区建议QQ群:365716997

分类

0 投票
764 浏览
If[#1 > 2, 2 #0[#1 - #0[#1 - 2]], 1] & /@ {1, 2, 5}
用户: 奋斗的大灰狼 (206 分)

1个回答

+2 投票
 
已采纳

Slot帮助里面有解释的,

首先,#0 stands for the whole pure function:

 f[#0] &[x]
 f[f[#0] &]

然后看个递归定义的例子,A recursive definition for factorial using #0:

f = If[#1 == 1, 1, #1 #0[#1 - 1]] &
f[10]
10!

输出 

If[#1 == 1, 1, #1 #0[#1 - 1]] &
3628800
3628800

所以f=If[#1 > 2, 2 #0[#1 - #0[#1 - 2]], 1] & 相当于g = If[#1 > 2, 2 g[#1 - g[#1 - 2]], 1] &

f=If[#1>2,2 #0[#1-#0[#1-2]],1]&;
g=If[#1>2,2 g[#1-g[#1-2]],1]&;
f /@ Range[10]
g /@ Range[10]

输出

{1, 1, 2, 4, 4, 2, 4, 4, 8, 4}
{1, 1, 2, 4, 4, 2, 4, 4, 8, 4}

 

用户: 随堂测验 (606 分)
采纳于 用户:奋斗的大灰狼
...