<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="zh-Hans-CN">
	<id>https://wiki.xhsr.org.cn/index.php?action=history&amp;feed=atom&amp;title=Y%E7%BB%84%E5%90%88%E5%AD%90</id>
	<title>Y组合子 - 版本历史</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.xhsr.org.cn/index.php?action=history&amp;feed=atom&amp;title=Y%E7%BB%84%E5%90%88%E5%AD%90"/>
	<link rel="alternate" type="text/html" href="https://wiki.xhsr.org.cn/index.php?title=Y%E7%BB%84%E5%90%88%E5%AD%90&amp;action=history"/>
	<updated>2026-06-03T02:53:06Z</updated>
	<subtitle>本wiki上该页面的版本历史</subtitle>
	<generator>MediaWiki 1.39.12</generator>
	<entry>
		<id>https://wiki.xhsr.org.cn/index.php?title=Y%E7%BB%84%E5%90%88%E5%AD%90&amp;diff=1146&amp;oldid=prev</id>
		<title>2022年2月10日 (四) 03:23 Rmolives</title>
		<link rel="alternate" type="text/html" href="https://wiki.xhsr.org.cn/index.php?title=Y%E7%BB%84%E5%90%88%E5%AD%90&amp;diff=1146&amp;oldid=prev"/>
		<updated>2022-02-10T03:23:24Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;新页面&lt;/b&gt;&lt;/p&gt;&lt;div&gt;&amp;#039;&amp;#039;&amp;#039;Y组合子（Y Combinator）&amp;#039;&amp;#039;&amp;#039;，是在无类型Lambda演算中计算其他函数的一个不动点的高阶函数。&lt;br /&gt;
&lt;br /&gt;
对于&amp;#039;&amp;#039;&amp;#039;Y组合子&amp;#039;&amp;#039;&amp;#039;来说，我们有&amp;lt;math&amp;gt;\textsf{Y}\ f = f&amp;lt;/math&amp;gt;。使得对于任何函数都有&amp;lt;math&amp;gt;\textsf{Y}\ f = f\ (\textsf{Y}\ f)&amp;lt;/math&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== 定义 ==&lt;br /&gt;
通常我们使用Lambda将Y组合子定义为&amp;lt;math&amp;gt;\textsf{Y} = \lambda f.(\lambda x.f\ (x\ x))\ (\lambda x.f\ (x\ x))&amp;lt;/math&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== 证明 ==&lt;br /&gt;
&amp;lt;math&amp;gt;(\textsf{Y}\ g)&amp;lt;/math&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;math&amp;gt;= (\lambda f.(\lambda x.(f (x\ x))\ \lambda x.(f\ (x\ x)))\ g)&amp;lt;/math&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;math&amp;gt;= (\lambda x.(g\ (x\ x))\ \lambda x.(g\ (x\ x)))&amp;lt;/math&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;math&amp;gt;= (\lambda y.(g\ (y\ y))\ \lambda x.(g\ (x\ x)))&amp;lt;/math&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;math&amp;gt;= (g\ (\lambda x.(g\ (x\ x))\ \lambda x.(g\ (x\ x))))&amp;lt;/math&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;math&amp;gt;= (g\ (\textsf{Y}\ g))&amp;lt;/math&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== 实现 ==&lt;br /&gt;
在实际中也可以顺利的实现它，比如编程语言&amp;#039;&amp;#039;&amp;#039;Scheme&amp;#039;&amp;#039;&amp;#039;：&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;racket&amp;quot; line&amp;gt;&lt;br /&gt;
(define Y&lt;br /&gt;
  (lambda (f) ((lambda (x) (f (lambda (y) ((x x) y))))&lt;br /&gt;
    (lambda (x) (f (lambda (y) ((x x) y)))))))&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== 用处 ==&lt;br /&gt;
用来实现递归&lt;br /&gt;
&lt;br /&gt;
=== 编程 ===&lt;br /&gt;
&lt;br /&gt;
我们还是用语言&amp;#039;&amp;#039;&amp;#039;Scheme&amp;#039;&amp;#039;&amp;#039;为例子，实现一个阶乘&lt;br /&gt;
&lt;br /&gt;
正常情况下我们可以给函数命名来实现：&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;racket&amp;quot; line&amp;gt;&lt;br /&gt;
(define f (lambda (n) (cond ((= n 0) 1)&lt;br /&gt;
                            (else (* n (f (- n 1)))))))&lt;br /&gt;
(print (f 10))&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
但是在函数不能被命名的情况下，就用到了Y组合子：&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;racket&amp;quot; line&amp;gt;&lt;br /&gt;
(define Y&lt;br /&gt;
  (lambda (f) ((lambda (x) (f (lambda (y) ((x x) y))))&lt;br /&gt;
    (lambda (x) (f (lambda (y) ((x x) y)))))))&lt;br /&gt;
(print ((Y (lambda (f) (lambda (n) (cond ((= n 0) 1)&lt;br /&gt;
                            (else (* n (f (- n 1)))))))) 10))&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
或者：&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;racket&amp;quot; line&amp;gt;&lt;br /&gt;
(print (((lambda (f) ((lambda (x) (f (lambda (y) ((x x) y))))&lt;br /&gt;
    (lambda (x) (f (lambda (y) ((x x) y)))))) (lambda (f) (lambda (n) (cond ((= n 0) 1)&lt;br /&gt;
                            (else (* n (f (- n 1)))))))) 10))&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Lambda ===&lt;br /&gt;
Lambda是匿名函数，Y组合子是为了解决递归时不能用名称指代原始函数的问题的。&lt;br /&gt;
&lt;br /&gt;
[[Category:计算机]]&lt;/div&gt;</summary>
		<author><name>Rmolives</name></author>
	</entry>
</feed>