稳定婚姻问题和延迟认可算法
稳定婚姻匹配问题(Gale-Shapley算法)(转载)

稳定婚姻匹配问题(Gale-Shapley算法)(转载)1962 年,美国数学家 David Gale 和 Lloyd Shapley 发明了⼀种寻找稳定婚姻的策略。
不管男⼥各有多少⼈,不管他们各⾃的偏好如何,应⽤这种策略后总能得到⼀个稳定的婚姻搭配。
换句话说,他们证明了稳定的婚姻搭配总是存在的。
有趣的是,这种策略反映了现实⽣活中的很多真实情况。
两对夫妻M1 F2,M2 F1。
M1⼼⽬中更喜欢F1,但是他和F2结婚了,M2⼼⽬中更喜欢F2,但是命运却让他和F1结婚了,显然这样的婚姻是不稳定的,随时都可能发⽣M1和F1私奔或者M2和F2私奔的情况。
所以在做出匹配选择的时候(也就是结婚的时候),我们需要做出稳定的选择,以防这种情况的发⽣。
稳定婚姻是组合数学⾥⾯的⼀个问题。
问题⼤概是这样:有⼀个社团⾥有n个⼥⽣和n个男⽣,每位⼥⽣按照她的偏爱程度将男⽣排序,同时每位男⽣也按照⾃⼰的偏爱程度将⼥⽣排序。
然后将这n个⼥⽣和n个男⽣配成完备婚姻。
如果存在两位⼥⽣A和B,两位男⽣a和b,使得A和a结婚,B和b结婚,但是A更偏爱b⽽不是a,b更偏爱A⽽不是B,则这个婚姻就是不稳定的,A和b可能背着别⼈相伴⽽⾛,因为他俩都认为,与当前配偶⽐起来他们更偏爱各⾃的新伴侣。
如果完备婚姻不是不稳定的,则称其是稳定的。
通过证明,可以得到每⼀个n⼥n男的社团,都存在稳定婚姻的结论。
但是这种情况只在异性的社团中存在。
也就是说在同性的社团⾥⾯,稳定婚姻的存在性将不再被保证。
解决思路如下⾸先选择⼀个单⾝男⽣,他会按照他的喜欢程度对⼀个还没有表⽩过的⼥⽣表⽩。
如果⼥⽣此时处于单⾝状态,则恭喜,他们两⼈将进⼊约会状态。
如果⼥⽣已经有男朋友,则⼥⽣会⽐较当前男朋友与表⽩的男⽣,如果更喜欢表⽩的男⽣,则恭喜,男⽣成功上位,⼥⽣之间的男朋友则进⼊单⾝状态;若⼥⽣还是更喜欢⾃⼰的男朋友,则不好意思,男⽣表⽩失败。
当所有的男⽣都脱离单⾝状态时,此时的约会状态应是稳定的,证明如下:若存在之前描述的不稳定因素,即虽然男⽣i和⼥⽣a牵⼿,但男⽣i对⼥⽣b更喜欢,⽽⼥⽣b发现,相⽐⾃⼰的男朋友j,她更喜欢男⽣i。
基于稳定婚姻问题的最大权匹配模型分析

基于稳定婚姻问题的最大权匹配模型分析稳定婚姻问题(Stable Marriage Problem)是一个经典的组合优化问题,最早由美国数学家D.Gale和L.S.Shapley于1962年提出,它解决的是在配对过程中如何以最优的方式匹配男女双方,使得不存在任何一对男女在匹配过程中想要放弃自己当前的匹配并改匹配到对方。
该问题可以用一个图论模型来表示,其中男性和女性分别被表示为两组节点,边代表男性对女性的偏好程度。
假设有n个男性和n个女性,每个人按照自己对异性的喜好对另一组进行排序。
稳定婚姻问题的目标是找到一个稳定的匹配,即不存在双方有更高偏好的配对。
为了解决这个问题,可以使用最大权匹配模型(Maximum Weight Matching)。
最大权匹配是一种图论算法,它的目标是找到图中权重之和最大的边集合,使得没有两个边共享相同顶点。
首先,我们需要建立一个稳定婚姻问题的图模型。
假设有两组顶点,男性集合M和女性集合W,共有n个顶点。
每个男性对女性的偏好程度可以表示为一个n×n的矩阵,矩阵中的元素表示男性对女性的排名。
同样,每个女性对男性的偏好程度也可以表示为一个n×n的矩阵。
接下来,我们需要使用最大权匹配算法来找到一个稳定的匹配。
最大权匹配算法采用了增广路径(Augmenting Path)的思想来不断寻找能够增大匹配权重的路径。
具体步骤如下:1. 随机选择一个男性,并让他向他排名最高的女性求婚。
如果女性尚未被任何男性求婚,或者她对当前求婚的男性更有好感,则将她与该男性匹配。
2. 如果女性已经与某个男性匹配,但是她对当前求婚的男性更有好感,则她与当前匹配的男性分手,与新的男性匹配。
3. 重复进行步骤1和步骤2,直到每个男性都结束了求婚。
4. 检查当前匹配是否稳定。
如果存在一对男女,他们彼此都有更高偏好的配对,那么该匹配不是稳定的。
5. 如果当前匹配是稳定的,则算法结束。
否则,从不稳定的一对中选择一个男性和女性,将他们分开,并再次进行求婚。
婚姻指数公式

婚姻指数公式
摘要:
一、婚姻指数公式的概念
二、婚姻指数公式的计算方法
三、婚姻指数公式在现实生活中的应用
四、婚姻指数公式的局限性与不足
五、结论
正文:
婚姻指数公式是一种衡量婚姻满意度的量化方法,通过计算夫妻间的相互关爱、沟通、信任、支持等各方面的表现,来评估他们的婚姻状况。
该公式由我国婚姻家庭专家提出,旨在帮助人们更好地了解和把握自己的婚姻状态,为婚姻家庭咨询和指导提供科学依据。
婚姻指数公式的计算方法主要包括以下几个步骤:
1.对夫妻双方在关爱、沟通、信任、支持等方面的表现进行评分
2.计算夫妻双方的平均分
3.用平均分相减得到婚姻指数
4.根据婚姻指数判断婚姻满意度等级
婚姻指数公式在现实生活中得到了广泛应用,不仅为婚姻家庭咨询和指导提供了有力支持,还能够帮助夫妻双方更好地了解自己的婚姻状况,及时发现问题并采取措施加以解决。
同时,婚姻指数公式还可以作为研究机构、政府部门等对婚姻家庭状况进行调查和分析的参考依据。
然而,婚姻指数公式也存在一定的局限性与不足。
首先,该公式主要关注夫妻间的互动表现,未能充分考虑个体差异和外部环境因素对婚姻状况的影响。
其次,婚姻指数公式在一定程度上忽视了婚姻生活中的情感性、复杂性和动态性,可能导致对婚姻状况的评估不够准确。
总之,婚姻指数公式作为一种量化方法,为婚姻家庭研究和指导提供了有益的工具。
二分图相关问题

X X S X X
X X X X
X代表攻击范围,S代表骑 士
分析
对棋盘染色,设方格的坐标为(x,y),x和y同奇 偶的方格对应X集合,不同奇偶的对应Y集合。 由于骑士沿着“日”字形路线攻击,所以每个 攻击肯定是处于X集合和Y集合之间,而不可 能在两个集合内部。 显然,转化后变为求二分图的最大独立集
匈牙利算法
简要说明:find函数用于判断从k点开始是否能 够找到一条交错路。对于每个可以与k匹配的 顶点j,假如它未被匹配,交错路就已经找到; 假如j已与某顶点x匹配,那么只需调用find(x) 来求证x是否可以与其它顶点匹配,如果返回 true的话,仍可以使j与k匹配;这就是一次 DFS。每次DFS时,要标记访问到的顶点 (cover[j]=true),以防死循环和重复计算。
例题分析
Hanoi Tower Troubles Again! (OIBH Contest)
ZOJ 1239 题目大意:给定柱子数N,按编号从小到大放球, 要求:如果该球不在最底数,则该球和它下面一个 球的编号之和必须为完全平方数。 问对于给定的N,最多能放多少球上去。 N<=50
例题分析
分析
铺放方法
1.2. .333 444. ..2.
Sample Output 4
分析
最小覆盖是覆盖所有的边,因此泥地对应边 建图方式类似于皇家卫士,也是利用行连通块 和列连通块做点,单位泥地对应二分图中的边 要求放最少的板覆盖全部的泥地,转化为求最 小覆盖
二分图最大独立集
图的独立集:寻找一个点集,其中任意两点在 图中无对应边 一般图的最大独立集是NP完全问题 二分图的最大独立集=图的点数-最大匹配数
二分图最小覆盖
图的覆盖:寻找一个点集,使得图中每一条边 至少有一点在该点集中
稳定婚姻问题算法

稳定婚姻问题算法
稳定婚姻问题是一个组合优化问题,可以使用算法求解。
一个常用的解决稳定婚姻问题的算法是Gale-Shapley算法。
下面是Gale-Shapley算法的伪代码:
1. 初始化所有人未匹配
2. 当存在一个男性未匹配的时候,选择一个未匹配男性m
3. 选择m的最喜欢的尚未婚配的女性w
4. 如果w未婚配,则将m和w配对
5. 如果w已婚配,但是m在w的排名上比当前配偶更好,则
将m和w配对,并将当前配偶变为未匹配状态
6. 重复步骤2-5直到所有男性都匹配
Gale-Shapley算法保证了最终的婚配结果是稳定的,即不存在
一个男性和一位女性,他们彼此喜欢对方胜过当前配偶的情况。
当然,除了Gale-Shapley算法,还有其他一些算法可以解决稳定婚姻问题,比如Stable Marriage with Incomplete Lists(SMI)算法等。
具体选择哪个算法取决于问题的规模和特点。
稳定婚姻问题和延迟认可算法

稳定婚姻问题和延迟认可算法作者:goal00001111 (高粱)始发于goal00001111 的专栏;允许自由,但必须注明作者和出处摘要:延迟认可算法(Gale-Shapley算法)是解决稳定婚姻问题的经典算法,本文用C++来实现Gale-Shapley算法。
文章详细介绍了Gale-Shapley算法的原理和编码思路,给出了一个直接从原理出发的原始算法及其改进版本,并对两个版本进行了比较分析。
关键词:稳定婚姻问题延迟认可算法二维数组以空间换时间稳定婚姻问题问题来自于一场“3分钟相亲”活动,参加活动的有n位男士和n位女士。
要求每位男士都要和所有的女士进行短暂的单独交流,并为她们打分,然后按照喜欢程度,对每一位女士进行排序;同样的,每位女士也要对所有男士进行打分和排序。
作为活动的组织者,当你拿到这些数据后,该如何为男,女士们配对,才能使大家皆大欢喜,组成稳定的婚姻呢?插一句:什么样的婚姻才能称为稳定的婚姻呢?所谓稳定的婚姻,就是指男女结婚后,双方都不会发生出轨行为。
那怎样才能做到双方都不出轨呢?如果双方都是对方的最爱,自然不会出轨;如果有一方或双方都不是对方的最爱,则必须保证想出轨的人找不到出轨的对象。
例如,男子i认为其妻子不是自己的最爱,他更爱的人是j女士,可是j女士认为自己的丈夫比男子i强,则不会选择与男子i出轨;另外有k女士很喜欢男子i,可是男子i又觉得她不如自己的现任妻子,所以也不会选择和k女士出轨。
这样男子i就找不到与之出轨的对象了;同理,如果他的妻子也找不到出轨对象的话,他们的婚姻就是稳定的。
简言之,只要满足“除妻子(丈夫)外,我爱的人不爱我,爱我的人我不爱”条件,就可形成稳定的婚姻。
回到我们的问题:如何让所有参加相亲活动的男女都组成各自的“稳定婚姻”?1962 年,美国数学家David Gale 和Lloyd Shapley 发明了一种寻找稳定婚姻的策略,人们称之为延迟认可算法(Gale-Shapley算法)。
婚姻量表计算方式

婚姻量表计算方式婚姻量表是一种用于测量婚姻质量的工具,它通过一系列问题或陈述,评估夫妻之间的满意度和关系质量。
婚姻量表可以帮助夫妻了解彼此的需求和期望,发现问题并寻求解决方案,进而改善婚姻质量。
婚姻量表的计算方式通常是基于回答者对一系列问题的评分。
这些问题涵盖了婚姻中的各个方面,如沟通、决策、亲密度、性生活等。
回答者需要根据自己在每个方面的体验和满意度,选择适合自己的评分。
评分通常采用一定的量表,例如5分量表或10分量表。
在5分量表中,回答者可以选择从1到5的等级,表示自己对该方面的满意程度。
而在10分量表中,回答者可以选择从1到10的等级,更细致地评估各个方面。
通过统计和分析回答者的评分,可以得出婚姻质量的综合评估。
一般来说,评分越高,表示婚姻质量越好;评分越低,表示婚姻质量越差。
同时,婚姻量表还可以根据不同的维度进行评估,例如情感维度、性满意度维度等,以更全面地了解婚姻的情况。
除了量表计算方式,婚姻量表的应用还需要考虑一些其他因素。
首先,婚姻量表的设计应该考虑到文化差异和个人差异,以确保问题的适用性和准确性。
不同的文化背景和个人经历可能会对婚姻产生不同的影响,因此量表需要在设计时充分考虑这些因素。
婚姻量表的结果应该结合其他信息进行解读。
量表只是婚姻质量的一个评估指标,不能完全代表整个婚姻的情况。
因此,在解读量表结果时,需要结合夫妻之间的互动、家庭环境、个人价值观等因素进行综合分析。
婚姻量表的应用应该是一个动态过程。
婚姻是一个发展和变化的过程,夫妻之间的关系也会随着时间和事件的变化而变化。
因此,婚姻量表的应用应该是一个连续的过程,定期进行评估,并根据评估结果进行相应的调整和改进。
婚姻量表是一种用于评估婚姻质量的工具,通过回答一系列问题并进行评分,可以得出夫妻之间的关系质量和满意度。
然而,婚姻量表的应用需要综合考虑文化差异、个人差异和其他信息,以确保评估的准确性和有效性。
同时,婚姻量表的应用应该是一个动态的过程,定期进行评估和调整,以促进夫妻关系的健康发展。
Gale-Shapley算法

什么是算法?每当有人问作者这样的问题时,他总会引用这个例子:假如你是一个媒人,有若干个单身男子登门求助,还有同样多的单身女子也前来征婚。
如果你已经知道这些女孩儿在每个男孩儿心目中的排名,以及男孩儿们在每个女孩儿心中的排名,你应该怎样为他们牵线配对呢?最好的配对方案当然是,每个人的另一半正好都是自己的“第一选择”。
这虽然很完美,但绝大多数情况下都不可能实现。
比方说,男1号最喜欢的是女1号,而女1号的最爱不是男1号,这两个人的最佳选择就不可能被同时满足。
如果好几个男孩儿最喜欢的都是同一个女孩儿,这几个男孩儿的首选也不会同时得到满足。
当这种最为理想的配对方案无法实现时,怎样的配对方案才能令人满意呢?其实,找的对象太完美不见得是好事儿,和谐才是婚姻的关键。
如果男1号和女1号各有各的对象,但男1号觉得,比起自己现在的,女1号更好一些;女1号也发现,在自己心目中,男1号的排名比现男友更靠前。
这样一来,这两人就可能抛弃各自现在的对象——如果出现了这种情况,我们就说婚姻搭配是不稳定的。
作为一个红娘,你深知,对象介绍得不好没关系,就怕婚姻关系不稳定。
给客户牵线配对时,虽然不能让每个人都得到最满意的,但搭配必须得稳定。
换句话说,对于每一个人,在他心目中比他当前伴侣更好的异性,都不会认为他也是一个更好的选择。
现在,我们的问题是:稳定的婚姻搭配总是存在吗?应该怎样寻找?一次失败的尝试为了便于分析,我们下面做一些约定。
我们用字母A、B、C对男性进行编号,用数字1、2、3对女性进行编号。
我们把所有男性从上到下列在左侧,括号里的数字表示每个人心目中对所有女性的排名;再把所有女性列在右侧,用括号里的字母表示她们对男性的偏好。
图1所示的就是2男2女的一种情形,每个男的都更喜欢女1号,但女1号更喜欢男B,女2号更喜欢男A。
若按A-1、B-2进行搭配,则男B和女1都更喜欢对方一些,这样的婚姻搭配就是不稳定的。
但若换一种搭配方案(如图2),这样的搭配就是稳定的了。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
稳定婚姻问题和延迟认可算法作者:goal00001111 (高粱)始发于goal00001111 的专栏;允许自由转载,但必须注明作者和出处摘要:延迟认可算法(Gale-Shapley算法)是解决稳定婚姻问题的经典算法,本文用C++来实现Gale-Shapley算法。
文章详细介绍了Gale-Shapley算法的原理和编码思路,给出了一个直接从原理出发的原始算法及其改进版本,并对两个版本进行了比较分析。
关键词:稳定婚姻问题延迟认可算法二维数组以空间换时间稳定婚姻问题问题来自于一场“3分钟相亲”活动,参加活动的有n位男士和n位女士。
要求每位男士都要和所有的女士进行短暂的单独交流,并为她们打分,然后按照喜欢程度,对每一位女士进行排序;同样的,每位女士也要对所有男士进行打分和排序。
作为活动的组织者,当你拿到这些数据后,该如何为男,女士们配对,才能使大家皆大欢喜,组成稳定的婚姻呢?插一句:什么样的婚姻才能称为稳定的婚姻呢?所谓稳定的婚姻,就是指男女结婚后,双方都不会发生出轨行为。
那怎样才能做到双方都不出轨呢?如果双方都是对方的最爱,自然不会出轨;如果有一方或双方都不是对方的最爱,则必须保证想出轨的人找不到出轨的对象。
例如,男子i认为其妻子不是自己的最爱,他更爱的人是j女士,可是j女士认为自己的丈夫比男子i强,则不会选择与男子i出轨;另外有k女士很喜欢男子i,可是男子i又觉得她不如自己的现任妻子,所以也不会选择和k女士出轨。
这样男子i就找不到与之出轨的对象了;同理,如果他的妻子也找不到出轨对象的话,他们的婚姻就是稳定的。
简言之,只要满足“除妻子(丈夫)外,我爱的人不爱我,爱我的人我不爱”条件,就可形成稳定的婚姻。
回到我们的问题:如何让所有参加相亲活动的男女都组成各自的“稳定婚姻”?1962 年,美国数学家David Gale 和Lloyd Shapley 发明了一种寻找稳定婚姻的策略,人们称之为延迟认可算法(Gale-Shapley算法)。
先对所有男士进行落选标记,称其为自由男。
当存在自由男时,进行以下操作:①每一位自由男在所有尚未拒绝她的女士中选择一位被他排名最优先的女士;②每一位女士将正在追求她的自由男与其当前男友进行比较,选择其中排名优先的男士作为其男友,即若自由男优于当前男友,则抛弃前男友;否则保留其男友,拒绝自由男。
③若某男士被其女友抛弃,重新变成自由男。
在算法执行期间,自由男们主动出击,依次对最喜欢和次喜欢的女人求爱,一旦被接受,即失去自由身,进入订婚状态;而女人们则采取“守株待兔”和“喜新厌旧”策略,对前来求爱的男士进行选择:若该男子比未婚夫强,则悔婚,选择新的未婚夫;否则拒绝该男子的求婚。
被女友抛弃的男人重获自由身,重新拥有了追求女人的权利——当然,新的追求对象比不过前女友。
这样,在算法执行期间,每个人都有可能订婚多次——也有可能一开始就找到了自己的最爱,从一而终——每订一次婚,女人们的选择就会更有利,而男人们的品味则越来越差。
只要男女生的数量相等,则经过多轮求婚,订婚,悔婚和再订婚之后,每位男女最终都会找到合适的伴侣——虽然不一定是自己的最爱(男人没能追到自己的最爱,或女人没有等到自己的最爱来追求),但绝对不会出现“虽然彼此相爱,却不能在一起”的悲剧,所有人都会组成稳定的婚姻。
本文用C++来实现Gale-Shapley算法,采用男士主动求爱,女士接受求爱的方式。
假设男女生人数均为MAX,对每位男士和女士均进行编号,用自然数0,1,2,。
,MAX-1表示其序号(依照C++的习惯,序号从0开始)。
用二维数组liMan[MAX][MAX]来存储男士所喜欢的女士序号的排列表;同理,用二维数组libLady[MAX][MAX+1]来存储女士所喜欢的男士序号的排列表,例如v号女最喜欢i号男,则libLady[v][0] = i;若t号男比i号男更招v号女喜欢,则在数组libLady[v][]中,元素值t的下标小于元素值i的下标。
为了简化算法,增加一个“不存在”的男士(序号为MAX),作为女士最初的选择。
在给二维数组libLady[MAX][MAX+1]赋初值时,对于任意一个女士v,总有libLady[v][MAX] = MAX。
为所有的男士(包括那个“不存在”的)建立一个数组man[MAX+1],用来存储他们追求女士的次数,i 号男目前追求的女士序号为libMan[i][man[i]]。
例如,man[i]=0表示i号男尚未追求过女士,其所追求的女士序号为libMan[i][0];man[i]=2表示i 号男已经追求过两位女士,他下次追求的女士序号为libMan[i][2](即在喜好表中排名第3位的女士)。
很明显,man[MAX+1]的每个元素初始值均为0,表示刚开始时,每位男士都去追求自己最喜欢的女士,man[i]值越大,男士对所选择的女士越不满意。
为所有的女士建立一个数组lady[MAX],用来存储她所选择的男士序号,数组的所有元素初始值均为MAX,表示女士的当前男友为一个“不存在”的男士,他的分值比任何男士都低,以保证当有一个真正的男人追求该女士时,她会毫不犹豫的抛弃MAX,而选择该男子。
我们遍历数组man[MAX+1],依次让每个男士去追求自己心仪的女士(当然不需要处理元素man[MAX]——那个“不存在”的男人)。
例如现在正逢i号男追求v号女,若i号男不如v号女当前男友,则遭拒绝,i号男继续追求其“次喜欢女”;反之,若i号男比v号女当前男友优秀,则v抛弃前男友,选择i号男为新男友,而其前男友(设为t号男)重获自由身,可以去追求自己的“次喜欢女”了。
这里有一个地方要注意:因为我们是通过执行(i++)来遍历数组的,所以如果当t<i时,必须要让i折回到t位置(使i=t),否则会漏掉t。
当i == MAX时,表示所有男士都找到了自己的另一半,算法结束,输出结果。
C++代码如下:#include <iostream>using namespace std;const int MAX = 4;bool ChangeFriend(const int libLady[][MAX+1], int v, int oldF, int newF);//判断是否需要换男友int main(){int libMan[MAX][MAX] = {{2,1,3,0},{0,2,3,1},{2,3,1,0},{1,3,2,0}};//存储男士所喜欢的女士序号的排列表int libLady[MAX][MAX+1] ={{0,3,1,2,MAX},{1,3,2,3,MAX},{0,2,3,1,MAX},{1,0,3,2,MAX}};//存储女士所喜欢的男士序号的排列表int man[MAX+1] = {0};int lady[MAX] = {MAX,MAX,MAX,MAX};int i = 0;while (i < MAX ){int v = libMan[i][man[i]]; //i号男喜欢v号女if (i == lady[v]) //i号男就是v号女当前男友,跳过,处理下一个男士i++;else if (ChangeFriend(libLady, v, lady[v], i)) //若i号男比v号女当前男友优秀,则v抛弃前男友,重新选择i{int t = lady[v]; //存储前男友序号man[lady[v]]++; //抛弃前男友,即前男友选择其“次喜欢女”lady[v] = i; //选择i号男为新男友if (t > i) //前男友序号t在新男友i之后,则今后顺序前行可以处理ti++; //处理下一个男士else //前男友序号t在新男友i之前,返回t,否则会漏掉ti = t;}else //继续处理i号男的“次喜欢女”man[i]++;}for (int i=0; i<MAX; i++)//输出每位男士追求女士的次数cout << man[i] + 1 << ", ";cout << endl;for (int i=0; i<MAX; i++)//输出每位男士的妻子的序号cout << libMan[i][man[i]] << ", ";cout << endl;for (int i=0; i<MAX; i++)//输出每位女士的丈夫的序号cout << lady[i] << ", ";cout << endl;system("pause");return 0;}bool ChangeFriend(const int libLady[][MAX+1], int v, int oldF, int newF)//判断是否需要换男友{for (int i=0; i<=MAX; i++){if (libLady[v][i] == oldF){oldF = i;break;}}for (int i=0; i<=MAX; i++){if (libLady[v][i] == newF){newF = i;break;}}return (oldF > newF);}在上述实现中,我设计了一个子函数bool ChangeFriend(const int libLady[][MAX+1], int v, int oldF, int newF),用来判断女士v是否需要换男友,若男子序号newF在数组libLady[v][i]的位置比oldF靠前,则说明女士v更喜欢newF,需要换男友,否则不换。
通过比较它们的下标,可以得出结论。
这个子函数的引入可以让程序完成工作,但也带来一些效率上问题,每次调用函数都要分别遍历数组libLady[v][]两次,去寻找oldF和newF的下标,这样在MAX值很大的时候,时间消耗是相当大的。
另外,由于我们是通过执行(i++)来遍历数组,每次遇到(t < i)时,都要令i折回到t,然后再执行(i++),进行了很多重复的比较,浪费了宝贵的时间。
那么,如何改进代码,解决上述两个问题?首先解决关于子函数的问题。
之所以引入子函数,是因为数组libLady[v][]存储的是女士v所喜欢的男士序号的排列表,而不是男士的分值表。
如果我们创建一个二维数组libladyValue[MAX][MAX+1],用来存储女士v所喜欢的男士的分值,即数组元素libladyValue[v][i]表示女士v给i号男打的分数,分数越高,则表示越招人喜欢。