实现纸牌游戏的随机抽牌洗牌过程(item系列几个内置方法的实例)

1、namedtuple:命名元组,可以创建一个没有方法只有属性的类
from collections import namedtuple
card = namedtuple('card',['rank','suit']) # rank 牌面大小,suit牌面的花色
# card其实就是namedtuple创建的一个类,其属性就是rank和suit
c1 = card(,'红心 ')
# c1是实例化的对象
print(c1)
print(c1.suit)

运行结果:

card(rank=2, suit='红心 ')
红心2
2、按照循环顺序,通过对象[索引]任意取牌
from collections import namedtuple
Card = namedtuple('Card',['rank','suit']) # rank 牌面大小,suit牌面的花色
class FranchDeck:
ranks = [str(n) for n in range(2,11)]+list('JQKA')
suits = ['红心','方板','梅花','黑桃']
def __init__(self):
self._cards = [Card(rank,suit) for rank in FranchDeck.ranks for suit in FranchDeck.suits]
# 嵌套循环,每循环一次都拿到一张牌,并且都会存到一个列表中,这个里面的牌是按照循环的顺序的
def __getitem__(self, item):
return self._cards[item] deck = FranchDeck()
print(deck[10]) # 出现对象加索引的的取法就是触发__getitem__方法

运行结果:

Card(rank='', suit='梅花')

Process finished with exit code 0
3、choice实现随机抽取一张纸牌的过程
from collections import namedtuple
Card = namedtuple('Card',['rank','suit']) # rank 牌面大小,suit牌面的花色
class FranchDeck:
ranks = [str(n) for n in range(2,11)]+list('JQKA')
suits = ['红心','方板','梅花','黑桃']
def __init__(self):
self._cards = [Card(rank,suit) for rank in FranchDeck.ranks for suit in FranchDeck.suits]
# 嵌套循环,每循环一次都拿到一张牌,并且都会存到一个列表中,这个里面的牌是按照循环的顺序的 def __getitem__(self, item):
return self._cards[item] def __len__(self):
return len(self._cards) # 实现按照循环循序抽取对应的纸牌
deck = FranchDeck()
print(deck[10]) # 出现对象加索引的的取法就是触发__getitem__方法 # 实现随机抽取一张牌的过程
from random import choice
print(choice(deck))
# 注意:# choice能够实现随机抽取纸牌,必须得依赖__len__方法,如果前面没有定义__len__方法就会报错,
# 即只要用到choice就会触发__len__方法

运行结果:

Card(rank='A', suit='梅花')

Process finished with exit code 0
4、shuffle实现随机洗牌的过程
from collections import namedtuple
Card = namedtuple('Card',['rank','suit']) # rank 牌面大小,suit牌面的花色
class FranchDeck:
ranks = [str(n) for n in range(2,11)]+list('JQKA')
suits = ['红心','方板','梅花','黑桃']
def __init__(self):
self._cards = [Card(rank,suit) for rank in FranchDeck.ranks for suit in FranchDeck.suits]
# 嵌套循环,每循环一次都拿到一张牌,并且都会存到一个列表中,这个里面的牌是按照循环的顺序的 def __getitem__(self, item):
return self._cards[item] def __len__(self):
return len(self._cards) # 传纸牌的长度,是从这么多张纸牌里面抽取 def __setitem__(self, key, value):
self._cards[key] = value deck = FranchDeck()
print(deck[10])
# 通过shuffle和__setitem__实现随机洗牌的过程,如果前面没有定义__setitem__方法同样会报错
# 因为随机洗牌的过程索引对应的牌就会发生改变,所以只能通过__setitem__去改变
from random import shuffle
shuffle(deck)
print(deck[10])

运行结果:

Card(rank='', suit='梅花')
Card(rank='K', suit='红心')
总结:
以上纸牌游戏实现随机抽牌,洗牌的过程,仅仅只是用了内置的方法,并没有用我们自己定
义的方法就实现了,需要注意的是: __getitem__与对象[索引],__len__与choice,__setitem__与shuffle
必须同时结合使用
内置函数,内置模块,内置的基础类型<---->类的内置方法,比如:== <--->__eq__,len()<--->__len__
5、总代码----纸牌游戏随机取牌以及洗牌的过程
# 按照循环顺序,通过对象[索引]任意取牌
# choice实现随机抽取一张纸牌的过程
# shuffle实现随机洗牌的过程
import json
from collections import namedtuple
Card = namedtuple('Card',['rank','suit']) # rank 牌面大小,suit牌面的花色
class FranchDeck:
ranks = [str(n) for n in range(2,11)]+list('JQKA')
suits = ['红心','方板','梅花','黑桃']
def __init__(self):
self._cards = [Card(rank,suit) for rank in FranchDeck.ranks for suit in FranchDeck.suits]
# 嵌套循环,每循环一次都拿到一张牌,并且都会存到一个列表中,这个里面的牌是按照循环的顺序的 def __getitem__(self, item): # 通过对象[索引]进行触发
return self._cards[item] def __len__(self): # 通过choice进行触发
return len(self._cards) # 传纸牌的长度,是从这么多张纸牌里面抽取 def __setitem__(self, key, value): # 通过shuffle进行触发
self._cards[key] = value def __str__(self):
return json.dumps(self._cards,ensure_ascii=False) # 序列化 deck = FranchDeck() # 通过对象[索引]和__getitem__实现按照循环循序抽取对应的纸牌
print(deck[10]) # 出现对象加索引的的取法就是触发__getitem__方法 # 通过choice和__len__实现随机抽取一张牌的过程
from random import choice
print(choice(deck))
# choice能够实现随机抽取纸牌,必须得依赖内置的__len__方法,如果前面没有定义__len__方法就会报错
print(deck[10]) # 通过shuffle和__setitem__实现随机洗牌的过程
from random import shuffle
shuffle(deck)
print(deck[10])
print(deck) # 需要进行序列化才可以 print(deck[:5]) # 直接利用对象进行切片

运行结果:

Card(rank='', suit='梅花')
Card(rank='A', suit='红心')
Card(rank='', suit='梅花')
Card(rank='A', suit='梅花')
[["", "梅花"], ["", "梅花"], ["", "梅花"], ["", "方板"], ["", "方板"], ["Q", "红心"], ["", "红心"], ["J", "黑桃"], ["", "梅花"], ["J", "红心"], ["A", "梅花"], ["", "黑桃"], ["Q", "方板"], ["", "梅花"], ["", "红心"], ["A", "红心"], ["", "红心"], ["", "方板"], ["", "黑桃"], ["K", "黑桃"], ["", "方板"], ["Q", "梅花"], ["", "黑桃"], ["", "黑桃"], ["J", "梅花"], ["A", "黑桃"], ["", "红心"], ["", "红心"], ["", "红心"], ["J", "方板"], ["", "方板"], ["K", "方板"], ["K", "红心"], ["", "红心"], ["", "红心"], ["", "方板"], ["", "方板"], ["K", "梅花"], ["", "红心"], ["", "梅花"], ["", "黑桃"], ["", "方板"], ["Q", "黑桃"], ["", "梅花"], ["", "梅花"], ["", "黑桃"], ["", "黑桃"], ["", "梅花"], ["", "方板"], ["", "黑桃"], ["", "黑桃"], ["A", "方板"]]
[Card(rank='', suit='梅花'), Card(rank='', suit='梅花'), Card(rank='', suit='梅花'), Card(rank='', suit='方板'), Card(rank='', suit='方板')]

实现纸牌游戏的随机抽牌洗牌过程(item系列几个内置方法的实例)的更多相关文章

  1. 完美洗牌&洗牌

    完美洗牌问题,给定一个数组a1,a2,a3,...an,b1,b2,b3..bn,把它最终设置为b1,a1,b2,a2,...bn,an这样的. O(n)的算法,O(n)的空间. 对于前n个数,映射为 ...

  2. java list随机截取(洗牌)

    public void solution(){ List<Integer> givenList = Arrays.asList(1, 2, 3,4,5,6); Collections.sh ...

  3. Python字符串内置方法使用及年龄游戏深入探究

    目录 作业 ==程序代码自上往下运行,建议自上而下的完成下列任务== 作业 使用代码实现以下业务逻辑: 写代码,有如下变量name = " aleX",请按照要求实现每个功能: 移 ...

  4. 实现斗地主纸牌游戏---洗牌 发牌 看底牌的具体功能------Map集合存储方法 遍历的应用

    该Demo只是斗地主的游戏的一部分,实现的斗地主的组合牌  洗牌  发牌 看牌的功能,主要应用Map集合进行练习 package cn.lijun import java.util.ArrayList ...

  5. 【bzoj1965】 [Ahoi2005]SHUFFLE 洗牌 欧拉定理

    题目描述 为了表彰小联为Samuel星球的探险所做出的贡献,小联被邀请参加Samuel星球近距离载人探险活动. 由于Samuel星球相当遥远,科学家们要在飞船中度过相当长的一段时间,小联提议用扑克牌打 ...

  6. Hard 随机洗牌函数 @CareerCup

    第i个元素和index在[i,length-1]之间的一个数随机交换 package Hard; import CtCILibrary.AssortedMethods; /** * * Write a ...

  7. Craking the coding interview 面试题:完美随机洗牌

    给定一个序列,随机打乱这个序列,新产生的序列和任意一个序列产生的可能性是一样的,就是所谓的完美随机洗牌. 看下面的运行结果: 上面第一列是原数列,下面一行是新产生的打乱的数列. 基本思想:如果n-1个 ...

  8. C++分享笔记:扑克牌的洗牌发牌游戏设计

    笔者在大学二年级期间,做过的一次C++程序设计:扑克牌的洗牌发牌游戏.具体内容是:除去大王和小王,将52张扑克牌洗牌,并发出5张牌.然后判断这5张牌中有几张相同大小的牌,是否是一条链,有几个同花等. ...

  9. 随机洗牌算法Knuth Shuffle和错排公式

    Knuth随机洗牌算法:譬如现在有54张牌,如何洗牌才能保证随机性.可以这么考虑,从最末尾一张牌开始洗,对于每一张牌,编号在该牌前面的牌中任意一张选一张和当前牌进行交换,直至洗到第一张牌为止.参考代码 ...

随机推荐

  1. 利用tensorboard将数据可视化

    注:代码是网上下载的,但是找不到原始出处了,侵权则删 先写出visual类: class TF_visualizer(object): def __init__(self, dimension, ve ...

  2. 【转】Chrome——F12 谷歌开发者工具详解

    Chrome——F12 谷歌开发者工具详解 console source network

  3. 【原】接口mock作用

    1.前后端 接口定义完成 并发开工 2.测试拿到mock接口 编写用例 3.mock接口 模拟异常服务器返回值 500 404 4.mock接口 模拟数据 不修改线上数据库

  4. Go函数高级

    1. 函数的数据类型 package main import "fmt" func main() { /* go语言的数据类型: 基本数据类型: int,float,bool,st ...

  5. 【Python】爬虫原理

    前言 简单来说互联网是由一个个站点和网络设备组成的大网,我们通过浏览器访问站点,站点把HTML.JS.CSS代码返回给浏览器,这些代码经过浏览器解析.渲染,将丰富多彩的网页呈现我们眼前: 一.爬虫是什 ...

  6. map遍历删除

    List<Object> orderManageList = cacheService.values(key); Iterator<Object> it=orderManage ...

  7. Codeforces Round #622 (Div. 2) A. Fast Food Restaurant

    Tired of boring office work, Denis decided to open a fast food restaurant. On the first day he made ...

  8. Numpy Pandas

    数据分析 : 是把隐藏在一些看似杂乱无章的数据背后的信息提炼出来,总结出所研究对象的内在规律. 数据分析三剑客 -  Numpy Pandas Matplotlib # Numpy 基于一维或多维的数 ...

  9. Kakfa概述及安装过程

    一.概述 1. Kafka是由LinkedIn(领英)开发的一个分布式的消息系统,最初是用作LinkedIn的活动流(Activity Stream)和运营数据处理的基础 a. 活动流数据包括页面访问 ...

  10. SpringCloud全家桶学习之消息总线---SpringCloud Bus

    一.概述 ConfigClient(微服务)从ConfigServer端获取自己对应的配置文件,但是目前的问题是:当远程git仓库配置文件发生改变时,每次都是需要重启ConfigCient(微服务), ...