1-1 一摞有风格的纸牌之一摞

Posted 打不过小怪兽leer

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了1-1 一摞有风格的纸牌之一摞相关的知识,希望对你有一定的参考价值。

写在前面

昨天学习了怎么用namedtuple()方法生成一张纸牌的类。今天继续学习怎么生成一摞纸牌。

一摞有风格的纸牌之一摞

流畅的Python中给出的第一个例子是一摞有序的纸牌:

import collections

# 一摞有序的纸牌

Card = collections.namedtuple(‘Card‘, [‘rank‘, ‘suit‘])

class FrenchDeck:
    ranks = [str(n) for n in range(2,11)] + list(‘JQKA‘)
    suits = ‘spades diamonds clubs hearts‘.split()

    def __init__(self):
        self._cards = [Card(rank, suit) for suit in self.suits for rank in self.ranks]

    def __len__(self):
        return len(self._cards)

    def __getitem__(self, position):
        return self._cards[position]

上一节学习了Card类,这一节看一下FrenchDeck中的内容。

ranks是一个列表,在这个列表中,共有13个字符,为2到11和‘JQKA’,这就是列表表达式。

suits是一个代表扑克牌4中花色的列表,这个列表是通过切割字符串得到的。

初始化方法中,对一摞纸牌进行了初始化,并赋值给self._cards,这里为什么要加下划线呢?意义在哪里?

import collections
Card = collections.namedtuple(‘Card‘, [‘rank‘, ‘suit‘])

ranks = [str(n) for n in range(2,11)] + list(‘JQKA‘)
suits = ‘spades diamonds clubs hearts‘.split()

cards = [Card(rank, suit) for suit in suits for rank in ranks]
for r, s in cards:
    print({r: s})
>>>
{‘2‘: ‘spades‘}
{‘3‘: ‘spades‘}
{‘4‘: ‘spades‘}
...
{‘Q‘: ‘hearts‘}
{‘K‘: ‘hearts‘}
{‘A‘: ‘hearts‘}

说明:单下划线开头的变量,标明是一个受保护(protected)的变量,原则上不允许直接访问,但外部类还是可以访问到这个变量。这只是程序员之间的一个约定,用于警告说明这是一个私有变量,外部类不要去访问它。

FrenchDeck类中的__len__()方法是一个特殊方法,获取这摞扑克牌的长度,及统计共有多少张扑克牌。

FrenchDeck类中的__getitem__()方法也是一个特殊方法,用以获取这摞扑克牌中的一张扑克牌。

思考

  • 怎么获取这摞扑克牌中的第一张,第10张,最后一张?
  • 怎么随机获取一张扑克牌?--需要导入:random.choice
  • 怎么对扑克牌进行切片操作?
  • 怎么对扑克牌进行迭代操作,打印出所有的扑克牌?

写在后面

学习了这节内容,第一反应是,哇哦~我可以用Python写出99乘法表了,心动不如行动:

# 99乘法表
from collections import namedtuple
Rank = namedtuple(‘Rank‘, [‘row‘, ‘column‘])

table = [Rank(row, column) for row in range(1,10) for column in range(1, 10)]
print(table)
for row, column in table:
    # print("%d*%d=%2d" % (row, column, row * column), end=‘ ‘)
    print(row * column, end=‘ ‘)
    # OMG 怎么打印出99乘法表的格式呢?
    if column == 9:
        print("")
        
>>>
1 2 3 4 5 6 7 8 9 
2 4 6 8 10 12 14 16 18 
3 6 9 12 15 18 21 24 27 
4 8 12 16 20 24 28 32 36 
5 10 15 20 25 30 35 40 45 
6 12 18 24 30 36 42 48 54 
7 14 21 28 35 42 49 56 63 
8 16 24 32 40 48 56 64 72 
9 18 27 36 45 54 63 72 81

最后的结果如上,但是这不是我想要的啊,我想要的是小时候文具盒上那样的:

技术分享

TIPS: 这个故事告诉我们,你以为你会了,其实你还什么都不会。

以上是关于1-1 一摞有风格的纸牌之一摞的主要内容,如果未能解决你的问题,请参考以下文章

贪心codevs1098 均分纸牌

编程之美——一摞烙饼的排序(暴搜+剪枝)

我用分布式事务干掉了一摞简历

有一种游戏,有三根柱子,把一根柱子上的一摞从小到大排起来的圆盘挪到另一根柱子上,一次只能移动一个,

每天一道博弈论之“E&D”

woj1419 无聊的游戏