美文网首页python热爱者Python新世界程序员
别喊我打牌了, 我学了一年python已经不想赢了, 我输过吗?

别喊我打牌了, 我学了一年python已经不想赢了, 我输过吗?

作者: Python新世界 | 来源:发表于2018-07-31 14:06 被阅读49次
image

大家都玩过斗地主,规则就不再介绍了。

直接上一张朋友圈看到的残局图:

image image

最后都发现其实农民跑不掉。由于手工破解无法穷尽所有可能性,所以这道题究竟农民有没有妙手跑掉呢,只能通过代码来帮助我们运算了。

本文将简要讲述怎么通过代码来求解此类问题,在最后会公布残局的最后结果,并开源代码以供大家吐槽。

minimax

image

代码的核心思想是minimax。minimax可以拆解为两部分,mini和max,分别是最小和最大的意思。

image image

在牌局中是一样的,如果农民的一手牌,让地主无论如何应对都不能赢的话,那么可以说农民有必胜策略;否则,农民必输。

核心逻辑

image image

如果我们要用这个函数来模拟两个人的出牌,则还需要知道对手当前的所有牌:enemy_pokers。

这个函数的返回值,是轮到我me_pokers出牌时,是否能够必赢牌。如果能赢则返回真,否则返回假。

image

假设轮到我出牌时,如果我手上的牌都出完了,那么我将立刻知道我赢了;反之如果对手的牌都出完了,而我没有,则我失败了。

image

因为现在轮到我出牌,所以我首先需要知道我现在能出的所有手牌组合。注意:这个组合中,包括过牌(即不出牌)的策略。

image

现在我们要对所有可能的手牌组合进行遍历。

首先我需要知道,上一手对方出的牌是什么。

  • 如果对方上一手选择过牌,或者没有上一手牌,那么我这一轮必须不能过牌,但是我可以出任意的牌

  • 如果对手上一手出了牌,则我必须要出一个比它更大的牌或者选择这一轮直接过牌(不出牌)

关键点来了,在出完我的牌或选择过牌后,我们需要用一个递归调用来模拟对手下一步的行为。

image

全部Python代码如下:

image

构建

image image image image

效率

image

由于一副牌的可能手牌巨大,导致递归的分支数巨大。所以时间开销非常大,

image image

结果

image image

代码运算出来的结果是,农民没有必胜策略。换言之,只要地主会玩,农民不可能赢。我不可能输……

相关文章

  • 别喊我打牌了, 我学了一年python已经不想赢了, 我输过吗?

    大家都玩过斗地主,规则就不再介绍了。 直接上一张朋友圈看到的残局图: 最后都发现其实农民跑不掉。由于手工破解无法穷...

  • 少打牌

    大下雨天的,父母和我打牌,然后就一直没赢过,头都疼了。 我:老弟,我觉得我还是赢了几把的。 老弟:你真的赢了几把吗?

  • 我已经赢了

    比98年的乔丹还大2岁,和2016的科比同龄,我是有多年轻,我已经赢了

  • 发现老公藏私房钱了

    以前我不想老公抽烟,打牌和咬槟榔。他也比较自觉的把钱给我了,自己也没有留什么钱。 最近他打牌赢了一些钱,...

  • 打牌的诱惑

    今天是正月初八,亲戚走完了,孩子上学了,我变得无聊了。于是喊老公过来,咱们打牌吧?老公居然答应了!我翻箱倒柜...

  • 我已经不想你了

    我已经不想你了 只是手指还在不停弹奏 关于你的乐谱 我已经不想你了 只是嘴里还在不停哼唱 关于你的旋律 我已经不想...

  • “我已经不想结婚了”

    过年在家的你被催婚了么? 迈入2020年,90后也“喜提”30岁了。 恋爱久了,真的会不断地质问自己:到底是手机不...

  • 别拦着我,我已经决定了……

    夏天已经杀到,我的纠结症又犯了,前年的事情拖到去年,去年的想法又拖到今年的今天,所以这次要彻底了断了。 我叫峰,别...

  • 别喊我老爹

    我摸了张六条,我看着那六条,看了半天,不知道该咋办,我总觉得那里不对劲。 “老李。”洋洋喊我。 我抬头,牌...

  • 别喊我“帅哥”

    在这样一个看脸的社会,长得好看有着巨大的优势。但现在,帅哥美女显然已经不是长相的问题,而演变成了性别问题。在这样的...

网友评论

    本文标题:别喊我打牌了, 我学了一年python已经不想赢了, 我输过吗?

    本文链接:https://www.haomeiwen.com/subject/tufhvftx.html