七夕,诺奖得主用算法教你如何脱单

七夕来袭,又到了情侣们大秀恩爱,单身狗们咬牙切齿的季节。本着人道主义关怀,先给大家唱一曲单身狗之歌——

雌雄双兔傍地走,你还是条单身狗;

两个黄鹂鸣翠柳,你还是条单身狗;

路见不平一声吼,你还是条单身狗;

问君能有几多愁,你还是条单身狗。

听完是不是很想组个复仇者联盟,早上去卖花,晚上去卖套,凌晨去卖药?

还是你认为社会资源就这么多,拆散一对是一对,于是整晚都在大街上溜达,看哪一对不顺眼就冲上去扇姑娘一巴掌然后问她“不是说你爱我吗?”

还是你打算宅在家里重播非诚勿扰,幻想自己站在台上和24位姑娘演皇上选后妃的戏码?

如果你还在琢磨这些事情,恭喜你,弱爆了。

因为获得稳定的感情不仅仅是单身狗的个人问题,更是一个数学问题和经济问题——稳定匹配问题 (stable matching problem)。针对这个问题,早在1962年的时候,两位美国数学家和经济学家 David Gale 和 Lloyd Shapley(2012年诺贝尔经济学奖得主)给出了著名的 Gale-Shapley 算法。

什么是稳定匹配?

1962年,Gale 和 Shapley 发表了一篇名为大学招生与婚姻的稳定性 (College Admissions and the Stability of Marriage) 的论文,首次提出了稳定婚姻问题,研究在一夫一妻制度下并且每个男士最终都要和一个女士结婚时,男士和女士的配对关系。这个问题后来成为研究稳定匹配的典型例子。

他们所研究的问题是要促成 n 个男士和 n 个女士之间的 n 对婚姻(所有人都是异性恋)。为了使这些婚姻稳定,我们要求所有人都把n 个异性按照自己喜欢的程度排列出来,然后根据对异性的偏好顺序来安排婚姻,最终希望找到一个稳定的匹配方案。所谓稳定匹配,满足两个条件:首先,它是一个完美匹配(所有男士都娶到了唯一的老婆,所有女士都找到了唯一的老公);其次,它不含有任何不稳定因素(没人会离婚,没人会私奔)。

举个例子。如果我们要撮合许仙、法海、白素贞和小青四位组成两对夫妻,并且他们各自的偏好列表如下

因为只有两男两女,所以只可能有两种方案。

1.(许仙,小青),(法海,白素贞)

2.(许仙,白素贞),(法海,小青)

不管从任何角度出发,把许仙和白素贞分开都是一件残忍的事,法海他老人家因为当年干了这事,还被后人指责为不懂爱,数学当然也不会为拆散有情人提供理论依据。根据定义,第一个方案是不稳定的,原因是许仙和白素贞把彼此视为第一选择,如果强加给他们不同的配偶,在他们心里,依然把对方放在第一位,从而大大增加了出轨的可能性,所以第一个方案是不稳定的。

第二个方案是稳定的。稳定方案并不意味着每一个人都会和自己最爱的心上人在一起,在这个例子里,白素贞和小青都更加青睐许仙,但是许仙只有一个,这个时候起决定性因素的是她们各自在许仙心目中的地位。两对婚姻关系确定后,就算小青对许仙念念不忘,也只能是单相思,最多也就是在家拿法海出出气,逼他还俗、逼他吃肉、逼他减肥等等,如果小青不想单身就只能接受这段姻缘。这是婚姻关系在现实社会里的一个真实写照,并不是每个人都能和最爱的人在一起,这时候,人们的选择是自己所能追求到的最佳伴侣。

Gale-Shapley算法

根据Gale和Shapley,任何一个稳定婚姻问题都有解的,也就说至少一个方案是稳定的。具体算法如下:

(1) 确定每一位男士和每一位女士都是单身。

(2) 让每一位单身男士 m 向他名单里排位最靠前并且还没有发出过交往请求的女士 w 发出交往请求:

  • 如果这位女士 w 单身,就接受交往请求,并把他们的状态都改为交往中;
  • 如果这位女士已经是在交往中了,那么比较 m 和正在与 w 交往的男士m',如果 m 比 m' 在 w 的名单里更靠前,那么 w 就会和 m 开始交往,m' 恢复单身;
  • 如果 m' 比 m 更靠前,那么 w 就继续和 m' 交往,而 m 继续向他名单里的下一位女士发出交往请求。

(3) 当所有人都在交往中的时候,就让他们结婚吧!

如果算法读起来有点绕,那就看代码。假设 n 个未婚男士的集合 M 和 n 个未婚女士的集合 W。

再举个例子

这次出场的是唐僧师徒四人加上龙王三太子(白龙马)和中国古代四大美女西施、貂蝉、王昭君、杨玉环再加上才女蔡文姬。他们对各位异性的心仪顺序如下:

欢迎读者自行应用 G-S 算法,最后的结果是方案1:

(唐僧,西施),(悟空,昭君),(八戒,文姬),(沙僧,玉环),(三太子,貂蝉)

在这个例子中,无论是从那一个男士开始配对,或是在算法进行中改变配对顺序,得到的结果将是一样的。也就是说男士们的行动顺序对最终结果没有丝毫影响。能够影响结果的只有每个人心中的那一份排序。因此对每个男士而言,除了祈祷自己的竞争对手不要太强以外,最重要的就是提升自己在心仪姑娘心目中的地位。与其抢着出手,不如多花点时间提高自身的实力,以博得心仪姑娘更多的好感。

此外,如果有一男一女,都将对方视作第一人选,那么有情人必成眷属,比如例子中的文姬与八戒。在这种情况下,只要不把他们放在一起,就会引起方案的不稳定。所以只要我最爱的人最爱我,足矣。

在放心使用 G-S 算法之前我们还需要证明它给出的方案是稳定的。第一,这个算法是有限的,不会出现死循环或是没有结果的状况,原因是每个男士最多向 n 个女士求交往,所以最多 n*n 次请求后,算法结束。1997年,这个上界被美国数学家 Knuth 降低到 n*n - n +1。第二,证明稳定性。假设在 Gale-Shapley 算法产生的方案中有一位男士 m 向一位女士 w 求交往被拒绝,那么 w 必定正在和一位她更喜欢的男士 m' 交往,因此不可能出现 m 与 w 对彼此好感度都大于自己伴侣的可能性。

男士优先还是女士优先?

俗语有云,“男追女,隔层山;女追男,隔层纱。” 如果我们让女士们采取主动,而让男士们静候佳音,Gale-Shapley算法会不会更容易一点呢?会不会带给我们不同的结果呢?用上面的例子,这次让女士们选择男士交往,得到结果方案2:

(唐僧,昭君),(悟空,玉环),(八戒,文姬),(沙僧,貂蝉),(三太子,西施)

和男生先选的方案1进行比较 (括号里是心仪顺序)

虽然这两个方案都是稳定的,但是是不同的。除了八戒,其他男生在两种方案中的配偶都不相同。那么哪一种方案更好呢?

  • 对唐僧而言,方案1更好,因为西施是4号人选而昭君是最差选择。
  • 对悟空来说,方案1更好,因为昭君是3号人选而玉环是4号人选。
  • 对沙僧来说,方案1更好,因为玉环是2号人选而貂蝉是3号人选。
  • 对三太子来说,方案1要好的多,因为貂蝉是最佳人选,而西施只排在第3位。

总体来说,男士们都倾向于第一方案。再来看看女士们的意见。为了方便,我们将两个方案的组合重新排列。

  • 对西施而言,方案2更好,三太子是2号人选,而唐僧是3号人选。
  • 对貂蝉来说,方案2是最佳方案,沙僧是第1人选,而三太子只排在第3位。
  • 对昭君来说,方案2更好,唐僧是2号人选,而悟空是4号人选。
  • 对玉环来说,方案2要好的多,悟空是最佳人选,而沙僧是3号人选。

所以全体女士都应该强烈倾向于第二方案。

于是我们得到了一个重要的推理:Gale-Shapley 算法产生的稳定方案对于主动一方是最优方案,而对被动一方是最差方案。

小结

在这个喜大普奔的节日,看过了数学家和诺贝尔经济学奖得主的经典算法,诸位单身狗是不是已经找到过节的正确姿势了?

  1. 合理前提下,所有人都能找到伴侣;
  2. 只有主动出击才能最大化幸福,被动等来的往往是最差结果;
  3. 竞争激烈时,与其抢着出手,不如多花点时间提高自身的实力,以博得心上人更多的好感;
  4. 最爱的人爱我,此生足矣;
  5. 并不是每个人都能和最爱的人在一起,如果不能,选择你所能追求到的最佳伴侣。

原文发布时间为:2015-08-20

时间: 2024-07-29 09:50:56

七夕,诺奖得主用算法教你如何脱单的相关文章

诺奖得主警示大公司病宁高宁全产业链战略遇问题

中粮集团董事长宁高宁在 对话环节(来源:新浪财经 陈鑫 摄) 诺奖得主奥利弗·威廉姆森在对话环节(来源:新浪财经 陈鑫 摄) 6月29日下午消息 2009年诺贝尔经济学奖得主奥利弗-威廉姆森今日在清华大学演讲时称,大企业集团多元化经营虽然可以分散行业风险,但其会增加决策时间引发下属公司的争夺.而近年来开始尝试全产业链的中粮集团董事长宁高宁也在同一场合直面其所面临的问题. 威廉姆森认为,大企业集团和多元化经营的集团在成长的过程中,通常是做过不少的并购,其提供的产品和服务业非常多元化.但与此同时,其

诺奖得主斯宾塞:坚信中国不会蒙受投资损失

美国东部时间2月12日(北京时间2月13日)消息,美国增长与发展委员会主席.诺奖得主迈克尔-斯宾塞(MichaelSpence)对新浪财经表示,坚信美国政府将继续支持"两房"现有债券,中国不会因此蒙受投资损失. 中国不会蒙受资产损失 本周五,奥巴马政府倡议逐步废除两大抵押贷款融资巨头房利美(FNM)和房地美(FRE),并承诺将继续为两房提供支持,以确保其能够偿还所有债务.就此,中国持有"两房"的4500亿债券投资的去向引起社会各界的关注. 今日,美国增长与发展委员会

数据结构 单链表-设计算法在带头结点的单链表L中删除数据值最小的结点

问题描述 设计算法在带头结点的单链表L中删除数据值最小的结点 //单链表类型定义如下: typedef struct node { int data; struct node *next; } ListNode; typedef ListNode *LinkList; //设计算法在带头结点的单链表L中删除数据值最小的结点(设链表中各结点数据值 均不相同).函数的原型为:void f34(LinkList L)

数据结构算法设计: 请设计一个算法,统计一个循环单链表L中的结点个数。

问题描述 数据结构算法设计: 请设计一个算法,统计一个循环单链表L中的结点个数. 算法设计: 请设计一个算法,统计一个循环单链表L中的结点个数. 解决方案 int n = 0; while (L != NULL) { L = L->next; n++; } 解决方案二: /* counts the nodes in the list / int fuc(struct list head) { void *tmp; int i; if(!head) return -1; for(i = 1, tm

华人研究团队发现新粒子,这其中会有下一个诺奖得主吗?

雷锋网(公众号:雷锋网)按:作为杨振宁的学生,如果华人物理学家张首晟也获得诺贝尔物理学奖,那将是诺奖历史上的一件盛事,也将是中国的一件盛事. 图:张首晟 据7月21日出版的<科学>杂志报导,加利福尼亚大学洛杉矶分校王康隆课题组和美国斯坦福大学教授张首晟课题组.上海科技大学寇煦丰课题组等多个团队共同完成了一项重大发现:他们发现了正反同体的"天使粒子"--马约拉那(Majorana)费米子,结束了国际物理学界长达80年的漫长探索. 值得一提的是,作为近几年诺贝尔物理学奖的热门候

诺奖得主菲尔普斯出任新华都商学院院长

深圳特区报北京4月15日电(深圳报业集团驻京记者 罗勤 李萍)今天,福建闽江学院和福建新华都慈善基金会在北京宣布,聘请2006年诺贝尔经济学奖得主埃德蒙-菲尔普斯教授出任新华都商学院院长,首届任期三年.他将全面负责该商学院的战略定位.国际合作.人才引进.课程设计.日常教学和研究等. 2009年10月,新华都集团董事长陈发树将其个人持有的市值83亿元的有价证券捐赠给福建新华都慈善基金会.今年1月,福建新华都慈善基金会捐资5亿元支持闽江学院组建新华都商学院.经过3个多月的努力,成功聘请2006年诺贝

当当网获诺奖得主莫言作品电子书独家授权

11月30日消息,当当网获得诺贝尔文学奖得主莫言作品电子书的独家授权,莫言文集全套20本在当当网独家销售.据透露,20本莫言作品电子书的价格约为纸质书的三到五折. 莫言是我国首位诺贝尔文学奖获得者,引发的"莫言热"至今仍在持续升温.当当网凭借敏锐的市场触觉和出版物领域的影响力,与版权方达成合作,获得莫言作品全集在当当网以电子书的形式独家出售--其中包括了大家耳熟能详的<檀香刑>.<红高粱>.<蛙>.<生死疲劳>等作品. 文学评论家认为,莫

诺奖得主:债转股可解决美银行问题

诺贝尔经济学奖得主.美国经济学家斯蒂格利茨18日撰文指出,美国政府恢复金融秩序的措施代价高昂且错误,应当采取债转股的形式整顿金融体系. 斯蒂格利茨在法国<回声报>上撰文说,美国整顿金融体系的措施(向银行注资)代价过高且有问题,这是在补偿那些制造了当前经济混乱的人.他认为,债权转股权是一种可行办法. 斯蒂格利茨表示,债转股可以重新树立银行体系的信心,也可以在不损害纳税人利益的情况下刺激贷款消费.他谈到,"那些固定利率债券持有者不喜欢债转股这种方式,他们更愿意从政府那里得到大礼"

诺奖得主尤努斯称中国小额信贷落后印度20年

中新网北京10月28日电由商务部.社科院和全国妇联等联合主办的中国小额信贷发展促进网络2009年年会暨2009年中国小额信贷高峰论坛今天在北京闭幕.国际小额信贷之父.诺贝尔和平奖得主.孟加拉乡村银行总裁尤努斯教授在论坛上指出,经过调查发现,中国的小额信贷产业比印度.孟加拉.南美要落后20年. 尤努斯教授说,虽然中国经济近年来飞速发展,仍然有2亿贫困人口低于世界银行贫困标准.目前,中国城乡差别巨大,有些贫困农村比发达大城市落后几十年.小额信贷是改善贫困农民生存状况的有效途径. 除尤努斯教授外,中国