【趣话编程】诸葛亮 VS 司马懿,排序算法大战谁能笑到最后?

简介: 为将者,不通天文,不识地理,不学算法,庸才耳。诸葛亮 VS 司马懿,排序算法大战即将拉开帷幕,且跟我一起来看谁能笑到最后?

原文链接

阵前对峙

公元234年,蜀汉丞相诸葛孔明再度北伐。
一日,与司马仲达所率魏军两军相峙,二人阵前舌战。
image.png
司马曰:“诸葛村夫,吾与汝相斗数年,斗兵斗阵斗谋略,均已疲乏。今日,何不一改陈规,斗点新奇玩意?”
诸葛轻抚羽扇,言道:“仲达今日想比试些什么?”
image.png
“你我各遣相等数量兵士,立作一排,再互派一人至对方军前,看谁派遣之人先将这一排兵士按身高从低到高排序,谁就取胜,三局两胜制,输者撤军五十里,如何?”
诸葛不答,只是一边微笑,一边慢摇羽扇。
司马问道:“怎么?怕了?”
诸葛笑曰:“为将者,不通天文,不识地理,不知奇门,不晓阴阳,不明兵势, 不学算法,庸才耳。此乃小儿游戏,何怕之有?”
image.png
司马亦笑曰:“匹夫休要狂言,且比来一看。”

第一轮:插入 VS 选择

双方各自部署,第一轮,双方皆出十人,少倾,列队完毕。
蜀营王平:“丞相,末将请求出战,以插入排序法破之”
魏营孙礼:“大都督,末将愿往,以选择排序法取之”
待信令一出,王平孙礼皆开始重整队伍。
司马观王平策略,只见王平来到队伍起始,依次唤后一人出列,空出其位,随后将其与前面之人相比,若矮于前面之人,则继续向前,直到寻出比之更矮之人,则将出列之人置于其后,原来位置之人依次后移。多次重复后,队伍已逐渐呈自低向高之势排列
1.gif
而另一侧,魏将孙礼之法,却有不同。只见其从第一人开始,记录为最矮之人,随后从第二人开始,将其身高与最矮之人身高相比,一旦发现比最矮之人还小,则更新最矮之人编号为当前之人,一趟下来直至队伍末尾,便知晓谁是整个队伍最矮之人,将其与队伍第一位置交换,最矮之人便来到队伍最前面。接着从第二位置重复以上过程,逐步获取次矮之人,不多时,队伍亦逐渐呈自低向高之势排列
2.gif
两人几乎同时完成整个队伍的排序,然蜀将王平以微小优势领先完成,此一轮,蜀胜。

第二轮:冒泡 VS 希尔

第二轮,双方皆出百人,少倾,列队完毕。
蜀营魏延请命:“丞相,末将请求出战,以快速排序法定能取胜”
诸葛曰:“杀鸡焉用牛刀,区区百人之队,冒泡排序法足矣,此一轮还是让马岱出战吧”
魏延面露不悦。
蜀营派马岱出战,魏营遣郭淮出战。
待信令一出,二人皆开始调整队伍。
马岱来到队首,只见其从第一人开始,比较第一人与第二人之高矮,若第一人高于第二人,则交换两人站位。继续比较第二人与第三人,一趟结束,最末尾之人便为队伍中最高之人。接着来到队伍开头,故技重施,不断交换,一直将队伍中次高之人交换到倒数第二的位置。
3.gif
司马观之,叹曰:“诸葛亮徒有虚名,竟派马岱使用冒泡排序法,大量交换费时费力,我军稳操胜券了”
此刻,魏延大急:“丞相,那郭淮使的什么方法,像插入法又不像插入法,眼看就要完成了,丞相真该派我出战”
4.gif
诸葛不语,一旁王平言道:“上将军,依末将愚见,此貌似缩小增量排序法,又名希尔排序法,由插入排序法改进而来,早年由西域传入中原”。
片刻之后,郭淮率先完成队伍排列,此一轮,魏胜。

第三轮:归并 VS ??

第三轮,双方队列增至千人。
蜀营魏延再次请求出战。
诸葛问魏延:“文长(魏延,字文长)啊,你打算以何算法破之?”
魏延答:“丞相,末将方才已经告知,予以快速排序法破之”
诸葛摇头,“不可”
魏延不解,“有何不可?”
诸葛复曰:“我观司马懿此一轮必遣其子司马昭出战,司马昭此人我素有耳闻,同样擅使快速排序法,若你二人均以此法上阵,你可有把握胜之?”
魏延摇头:“倘若如此,末将并无十足把握”
诸葛轻挥羽扇,“此一局不宜使用快速排序法,姜维过来,本相另有良策传授与你”
image.png
魏延愤懑不平:“丞相为何视我为无物,末将不服”。
诸葛笑曰:“文长休急,本相另有重任相托”。
魏延大喜。
另一方魏营,司马昭曰:“父亲,孩儿研习快速排序法多年,此一轮愿请出战”
仲达怒斥:“军中无父子!”
昭大惊,改口:“是,大都督”
仲达缓捋长须,曰:“此一轮,不可用快速排序法
昭不明:“这是为何?”
快速排序法之要害,在于选择基准参考,并将队伍划分为矮于基准之人部分和高于基准之人部分。再缩小范围,复用此法,直至整个队伍有序。
5.gif
昭曰:“父亲,,,大都督所言不错,可为何不能使用此法?”
仲达指着队伍,言道:“诸将请看,千人之队,必有大量身高相等之人,若以快速排序法,势必做大量无用位置交换,徒耗不少功夫。快速排序法名曰快速,切不可纸上谈兵,还需审时度势,灵活变通才是”
司马昭点头,深以为然:“还是大都督老谋深算,末将虽研习多年,尤未可及也”
仲达于司马昭耳畔窃言数语,随即遣之出战。


司马昭来到队伍前面,将队伍分作两半,又将每一半继续分作两半,直至无可再分。接着按照大小合并每一个细分的部分为有序队伍,又进一步将这些有序队伍合并成更大的有序队伍,直至合并所有兵士为整体的有序队伍
6.gif
司马问道:“孔明,你可识得我儿司马昭所用排序之法?”
诸葛笑答:“别说是我,我蜀中三尺孩童也识得,此乃归并排序法,是也不是?”
司马未露声色,回看姜维,一不留神,姜维所排队伍竟已近尾声。
诸葛察之,问道:“仲达可识得姜维所用排序之法?”
司马细细观之,只见姜维从队首至队尾,依次询问所有人身高,并记录整个队伍之最矮与最高者,最终得最矮者六尺二寸,最高者八尺三寸。随即从六尺二寸、六尺三寸、六尺四寸,直至八尺二寸、八尺三寸共划分为二十二组。随后将所有人依次分入各组,再将各组依序合并。千人之队,不待半个时辰,竟将完成。
7.gif
片刻之后,姜维完成队列排序,此一轮,蜀胜。
司马仍未露声色,悄然返回军中,谓之左右曰:“诸葛亮果然有些本事,我不如也”
三局两胜,司马失利,依约后撤五十里,高挂免战牌,自此坚守不出。

彩蛋

撤军路上,昭问仲达:“大都督,蜀将姜维所用何法,竟能如此神速?”
不待仲达开口,前方一哨骑回报:“报~,大都督,蜀将魏延趁两军对峙,亲率两万铁骑攻我大营,我守将不备,大营给,给丢了”
司马怒目圆睁,摔下马去。


来源 | 编程技术宇宙
作者 | 轩辕之风
文中动图来源:《十大经典排序算法(动图演示)》

相关文章
|
6月前
|
算法 数据安全/隐私保护
火山中文编程 -- MD5算法和SHA算法
火山中文编程 -- MD5算法和SHA算法
54 0
火山中文编程 -- MD5算法和SHA算法
|
11天前
|
算法 Python
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果;贪心算法在每一步选择局部最优解,追求全局最优;动态规划通过保存子问题的解,避免重复计算,确保全局最优。这三种算法各具特色,适用于不同类型的问题,合理选择能显著提升编程效率。
28 2
|
1月前
|
存储 缓存 分布式计算
数据结构与算法学习一:学习前的准备,数据结构的分类,数据结构与算法的关系,实际编程中遇到的问题,几个经典算法问题
这篇文章是关于数据结构与算法的学习指南,涵盖了数据结构的分类、数据结构与算法的关系、实际编程中遇到的问题以及几个经典的算法面试题。
30 0
数据结构与算法学习一:学习前的准备,数据结构的分类,数据结构与算法的关系,实际编程中遇到的问题,几个经典算法问题
|
1月前
|
算法 Python
Python算法编程:冒泡排序、选择排序、快速排序
Python算法编程:冒泡排序、选择排序、快速排序
|
6月前
|
存储 分布式计算 算法
【底层服务/编程功底系列】「大数据算法体系」带你深入分析MapReduce算法 — Shuffle的执行过程
【底层服务/编程功底系列】「大数据算法体系」带你深入分析MapReduce算法 — Shuffle的执行过程
96 0
|
3月前
|
存储 算法 搜索推荐
编程之旅中的算法启示
【8月更文挑战第31天】在编程世界的迷宫里,算法是那把钥匙,它不仅能解锁问题的答案,还能引领我们深入理解计算机科学的灵魂。本文将通过一次个人的技术感悟旅程,探索算法的奥秘,分享如何通过实践和思考来提升编程技能,以及这一过程如何启示我们更深层次地认识技术与生活的交织。
|
4月前
|
存储 算法 搜索推荐
告别低效编程!Python算法设计与分析中,时间复杂度与空间复杂度的智慧抉择!
【7月更文挑战第22天】在编程中,时间复杂度和空间复杂度是评估算法效率的关键。时间复杂度衡量执行时间随数据量增加的趋势,空间复杂度关注算法所需的内存。在实际应用中,开发者需权衡两者,根据场景选择合适算法,如快速排序(平均O(n log n),最坏O(n^2),空间复杂度O(log n)至O(n))适合大规模数据,而归并排序(稳定O(n log n),空间复杂度O(n))在内存受限或稳定性要求高时更有利。通过优化,如改进基准选择或减少复制,可平衡这两者。理解并智慧地选择算法是提升代码效率的关键。
70 1
|
3月前
|
存储 算法
【C算法】编程初学者入门训练140道(1~20)
【C算法】编程初学者入门训练140道(1~20)
|
4月前
|
存储 算法 Python
震撼!Python算法设计与分析,分治法、贪心、动态规划...这些经典算法如何改变你的编程世界!
【7月更文挑战第9天】在Python的算法天地,分治、贪心、动态规划三巨头揭示了解题的智慧。分治如归并排序,将大问题拆解为小部分解决;贪心算法以局部最优求全局,如Prim的最小生成树;动态规划通过存储子问题解避免重复计算,如斐波那契数列。掌握这些,将重塑你的编程思维,点亮技术之路。
72 1
|
5月前
|
机器学习/深度学习 算法 搜索推荐
编程之舞:探索算法的优雅与力量
【6月更文挑战第10天】在软件的世界里,算法是构筑数字宇宙的基石。它们如同精心编排的舞蹈,每一个步骤都充满着逻辑的美感和解决问题的力量。本文将带领读者走进算法的世界,一起感受那些精妙绝伦的编程思想如何转化为解决现实问题的钥匙。
34 3