【组合数学】非齐次递推关系与编程

现在有一个问题:

我们想得到一个复杂运算的通式。

所谓通式就是类似 result = F(x) 的形式,只要我们给出输入 x,就可以利用通式得出计算结果。

有人会问这不是很简单吗?我们不就是这样解决问题的吗?

其实大多数情况下,我们可以这样解决问题。因为我们没有遇到复杂的问题,所以没有想过对应的解决办法。现在给出一个例子:

错排问题:

某网站收集了n个用户的个人信息。每个人手里有一张优惠券,现在网站搞混合抽奖,两两交换优惠券信息。最终每个人都获得了一张新的优惠券!

其实就是一个优惠券换优惠券的活动。

问题是:一共有多少种分配方案?

可以看到这道题有几个要点:

1、每个人获得的新优惠券不能还是原来自己的。

2、每个人都与其他人进行了交换,但多少次不管。且优惠券无重复。

我们没办法一下子写出通式来,即给我一个用户数量n,我就可以告诉你有几种分配方案。

而只能写出类似 An = A(n-1)+A(n+2)的递推表达式。(当然不是这个,这是斐波那契递推关系式)

那有人问,我就利用递推公式求出来不就好了吗?但你知道在计算机里递推用到的是“栈”,资源开销很大,在不知道复杂度的情况下,容易造成事故。

而如果我们用简单的加减乘除就能解决这个运算问题是不是节省了很多内存资源呢?

好戏就要上演了。

步骤:

1、换一种思想,既然用到递推,我们就设Dn代表n个用户有Dn个解决方案。

Dn就是我们最终要求的数。

2、类似的,D(n-1)代表n-1个用户的方案数。

我们不知道D(n-1)到底是多少,但是我们可以利用它。

①现在假定n-1个用户对应的方案数D(n-1)我们已经求出来了。

那第n个用户来了,他也要参加抽奖。我们想一想他跟谁交换优惠券呢?

对了,和任何人都行!因为n-1个人已经错排好了,而n现在和他们任何人交换,n拿的都不是自己的;拿到n手中优惠券的人也拿的不是自己的。所以这n个人就错排好了。

(结果:D(n-1)*(n-1))            (前一个(n-1)是下标,别搞混了。)

有人说这不是忽悠我吗?n-1个人的方案数还没告诉我呢。

先接着往下看。

②假设n个人都没交换呢,现在先让第n个人(对这个人比较特殊,他先交换)和n-1里的任意一个人交换。好了,我们就先不动他俩了。剩下还有n-2个人等待被交换,不管,先记做D(n-2)。这n个人也都被交换好了。

(结果:(n-1)*D(n-2)     )

综合①、②得出  n个人的交换方案:

D(n) = (n-1)*D(n-1) + (n-1)*D(n-2)    两个结果相加就得到了。

会有人疑惑这两种情况涵盖所有了吗?

我们来想一想,这其实是把问题分成了两类:

第n个人要么是在其他人交换完之后再交换,要么先交换。这两种情况都保证了第n个人得到了原不属于自己的优惠券。

那同理,第n-1个人也是这么分的……第1个人也是这么分的(只不过其他人数是0而已,共交换0次哈哈)

所以我们得到的递推公式是正确的!

D(n) = (n-1)*D(n-1) + (n-1)*D(n-2)                             ①

3、下面跟着我的步骤一步步化简。

式①可以写成:

D(n)  - nD(n-1) = - [ D(n-1) - (n-1)*D(n-2) ]

=……

= (-1)^(n-1) * (D1 - D0)

更清楚的推导看下图:

再往下↓
简化后的结果↓

经过一番推导,我们得出了“给定用户数n,求交换方案数Dn”的通式!

虽然结果比较复杂(大多数是这样),但其中原理着实让人着迷。

结语:

其实并不是所有的递推关系都能得到一个通式:对于“线性常系数齐次递推关系”可以百分百求出其通式,就像斐波那契数一样;而对于“线性常系数齐次递推关系”要看具体情况。

感兴趣的可以去wiki查这些关键词,或者看清华大学的视频教程。

地址在这:http://pan.baidu.com/s/1bpj4PMB

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

推荐阅读更多精彩内容