显示数字的挂衣架——母函数妙用示例

        上一篇文章《集合的精确平均划分》,经典的例子大可以作进一步的引申,继续挖掘下去,我们可以提出这样一个问题:

        对于哪些正整数n,只要确定从n个不同的数中任意选取的两个数的和,就可以唯一确定这n个数?


        如果没有具体的例子,题面还真不那么容易理解,好在我们可以拿出上一篇文章里精确划分的集合,如

或者

        不难验证,对于集合X中的任意两个数的和,在Y中一定有对应的两个数的和与之相等。例如X"中的11+13等于Y"中的9+15。也就是说,从n个数里任取两个数求和,即使和值都确定,也可能得到两个不同的集合,而不是唯一地确定一个n个数的集合!此时n=2^k。

        同样可以用数学归纳法给出证明,对于集合X,Y,是{1,2,…,2^k}的一个划分,假设有:

        xi+xj=yi+yj (1),

        提升到新的集合:

        可以总结出,X'中的两个数的和无非是如下三种形式之一:

        由归纳假设(1)式,显然xi+xj=yi+yj,且xi+xj+2^(k+1)=yi+yj+2^(k+1),而不论X'或Y',都包含集合X∪Y中的任意一个x与y。所以,X'与Y'中对应两数的和也是相等的。#

        我们猜测,也许结论是这样的:如果正整数n不等于2的幂,通过取两个数的和才可以唯一确定一个集合。但是,上面仅仅是举了一个2^k个元素的集合的例子,容易想到,如果所有集合的每个数都加上一个正整数m,这个结论显然也成立。我们感兴趣的是,能不能一般地求出n=2^k?

        首先要明确一点,为什么题面中强调是从n个不同的数中选取?对于集合

        假如集合X有两个数相同,每个数依次与X中所有其他数相加,会产生n-1对相同的和值,由(1)式,集合Y两元素相加,一定也有n-1对相同的和值,可知,Y中也有两个数相同。

        对于集合X,Y相同的两个数,由(1)式,显然xi=xj=yi=yj,即X,Y中有元素是相同的。xi=yi,再由(1)式,对所有的j相加,可得两集合X,Y是完全相同的。

        所以,要想通过取两个数的和不唯一地确定一个集合,首先要从n个不同数中选取。

        下面给出直接求解正整数n的方案。可以提前告诉大家,这是一个堪称经典的初等证明,把等式变换的魅力体现得淋漓尽致。设相应两元素之和相等的两个不同集合:

即对于任何不同的i≠j,xi+xj=yi+yj,设


        显然,p,q两式的平方的所有交叉项都是相等的,所以有

                                        (2)

        由p(1)=q(1)=n,可知方程p(z)-q(z)=0必有一个根是1,不妨设其重数为k,可得如下的因式分解形式,再经过变换:

        最后,令z=1,立得2n=2^k,即n是2的幂!

        凌波微步般精妙的等式变换直抵满足条件的那些n值,令人击节不已,难怪这个题面看起来并不精练的问题会令供职于著名的AT&T实验室的学者Nick Reingold念念不忘。回味一下,(2)式的设立高屋建瓴,若挈裘领,事实上,这一巧思并不神秘,只不过用到了所谓“母函数”的思想。

        何谓母函数?顾名思义,一定能生成某些东西,所以也叫“生成函数”。曾经是华罗庚的得力助手,在多复变函数论领域承华老衣钵的史济怀先生也是位杰出的科普作家,他曾经借助组合数来平易自然地引入母函数的概念。由二项式定理:

        系数是一个数列:


        这个数列可以认为是由函数(1+x)^n“产生”的,所以,f(x)=(1+x)^n就是数列的母函数。其实,我们早已在不知不觉借助母函数的方法,例如,由

        两边分别用二项式定理展开,可以轻松得到如下组合恒等式:

        这样的应用显然不能满足我们对新概念、新数学思想的求知欲,接下来就欣赏一个著名的“替换普通骰子”问题,属于一类用母函数来解决的典型问题:能否设计两个不同的骰子,使它们掷出某个点数之和的情况与两个普通骰子是一样的?也就是说,掷出的点数之和是3有2种方法,掷出点数和是7有6种方法,掷出12有1种方法等等。当然,每个骰子必须有6个面,每个面都用一个正整数标记。

        这个有趣的问题非常著名,甚至它的答案有个专门的名称:“Sicherman的骰子”,因为答案最早是由美国新泽西州的George Sicherman上校发现的,两枚骰子每个面的标记分别是{1,3,4,5,6,8}和{1,2,2,3,3,4}!

        我们用变量为x的多项式来表示其中的一颗骰子,x^k项的系数表示骰子上出现标记k的次数,显然,一颗普通的骰子对应的多项式就是:

        解答问题的关键是,掷两颗骰子的情况可以用它们对应的多项式的乘积来表示。比如,掷两颗普通骰子,乘积f^2(x)的x^10项的系数不过是从两个f(x)中各取一项相乘,使得乘积为x^10的方法数,掷出点数之和是10共有三种方法,如下:

        现在,设表示我们需要设计的骰子的多项式分别是g(x),h(x),掷出某个点数之和的情况相同,也就是

                                          (3)

        下面用到的方法并不陌生,无非是多项式的因式分解,f(x)可分解为

        要满足(3)式,无非是尝试一下,f式平方后的8个因式,怎么分配给g(x),h(x)。限制条件显然是,g(x)和h(x)里不能出现系数(方法数)为负的项,也不能出现非零的常数项——这一条表示骰子上不可能有面标记“0”,限制因式分解,要求两个因式x必须给g,h各分配一个。

        尝试几次,满足条件的只有如下的分配方式:

        取其系数,就是设计的答案{1,3,4,5,6,8}和{1,2,2,3,3,4}。Sicherman的骰子问题可以作出许多发散,至今仍然有数学工作者对此津津乐道。有兴趣的读者可以用同样的方法尝试一下一个新的问题:如果有种正八面体骰子,每个面分别标记数字1到8,能否以一对数字标记不同的八面体骰子作为它们的替代品?


        通过两个经典的例子,我们对于运用母函数分析问题的基本思想有了大致的了解。一言以蔽之,母函数把组合问题中的加法原理和幂级数的幂次项相加对应了起来。本文开篇从n个不同的数中任意选取两个数之和的例子里,离散数列间的结合关系被对应到幂级数间的运算关系。“取集合X中的任意两个数之和,在Y中一定有对应的两个数之和与之相等”的离散关系被神奇地转换成我们的“裘领”第(2)式,正因为有了这种对应,牧野鹰扬一般的数学想象力才被赋予了起飞之巢窠,进而探骊得珠。而在替换普通骰子的例子里,幂级数形式来确定离散数列的构造,实乃结构本天成,妙手偶得之。

        在组合数学中,母函数不仅是一件工具,还是一整套重要的理论。母函数有很多种类型,包括普通母函数、指数母函数、L级数、贝尔级数和狄利克雷级数等。西方哲学史上自古就有对所谓共相问题的争论,从个别具体的例子中抽提共同本质形成的抽象概念,反过来成了衡量具体例子的尺度,于是,后世一轮又一轮争论中双方的基本主张被不断赋予换汤不换药的新名词。在数学学习中,对于抽象的概念我以为一定要从具体的例子入手,且一例不通,不看下例。著有《发生函数(即母函数)论》一书的Herbert S. Wilf有个绝妙的比喻:母函数就是一列用来展示一串数字的挂衣架。在充满艺术气息的衣架博览会现场,与其走马观花浮光掠影,不如驻足一个细部,细玩一两件精妙而天成的设计。




       

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,519评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,842评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,544评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,742评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,646评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,027评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,513评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,169评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,324评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,268评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,299评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,996评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,591评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,667评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,911评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,288评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,871评论 2 341

推荐阅读更多精彩内容

  • 母函数 对于一般的排列组合算法题, 可首先尝试通过母函数来解决。 在数学中,某个序列的母函数(Generating...
    Teci阅读 2,965评论 3 27
  • 写了个程序,对Pandas的绝大部分函数及其说明进行了中文翻译。原网址:http://pandas.pydata....
    TSIANG阅读 5,260评论 0 4
  • 知识回顾 列表,字典,元组,集合 列表(list):[];可变,有序;元素是任何类型的数据增:append,ins...
    莫名ypc阅读 342评论 0 0
  • 控制流 Swift提供了各种控制流程语句。这些包括while循环多次执行任务; if,guard以及switch基...
    Fuuqiu阅读 362评论 0 0
  • 16宿命:用概率思维提高你的胜算 以前的我是风险厌恶者,不喜欢去冒险,但是人生放弃了冒险,也就放弃了无数的可能。 ...
    yichen大刀阅读 6,025评论 0 4