zoukankan      html  css  js  c++  java
  • Python collections.deque

    简介:
    collections 是 python 内建的一个集合模块,里面封装了许多集合类,其中队列相关的集合只有一个:deque。
    deque 是双边队列(double-ended queue),具有队列和栈的性质,在 list 的基础上增加了移动、旋转和增删等。

    常用方法:

    d = collections.deque([])
    d.append('a') # 在最右边添加一个元素,此时 d=deque('a')
    d.appendleft('b') # 在最左边添加一个元素,此时 d=deque(['b', 'a'])
    d.extend(['c','d']) # 在最右边添加所有元素,此时 d=deque(['b', 'a', 'c', 'd'])
    d.extendleft(['e','f']) # 在最左边添加所有元素,此时 d=deque(['f', 'e', 'b', 'a', 'c', 'd'])
    d.pop() # 将最右边的元素取出,返回 'd',此时 d=deque(['f', 'e', 'b', 'a', 'c'])
    d.popleft() # 将最左边的元素取出,返回 'f',此时 d=deque(['e', 'b', 'a', 'c'])
    d.rotate(-2) # 向左旋转两个位置(正数则向右旋转),此时 d=deque(['a', 'c', 'e', 'b'])
    d.count('a') # 队列中'a'的个数,返回 1
    d.remove('c') # 从队列中将'c'删除,此时 d=deque(['a', 'e', 'b'])
    d.reverse() # 将队列倒序,此时 d=deque(['b', 'e', 'a'])

    使用deque解决约瑟夫问题:

    """ 约瑟夫算法
    据说著名犹太历史学家 Josephus 有过以下的故事:
    在罗马人占领桥塔帕特后,39个犹太人与 Josephus 及他的朋友躲到一个洞中,
    39个犹太人决定宁愿死也不要被敌人抓到,于是决定了一个自杀方式,41个人排成一个圆圈,
    由第1个人开始报数,每报数到第3人该人就必须自杀,然后再由下一个重新报数,
    直到所有人都自杀身亡为止。然而 Josephus 和他的朋友并不想自杀,
    问他俩安排的哪两个位置可以逃过这场死亡游戏?
    """
    import collections
    def ysf(a, b):
        d = collections.deque(range(1, a+1)) # 将每个人依次编号,放入到队列中
        while d:
            d.rotate(-b) # 队列向左旋转b步
            print(d.pop()) # 将最右边的删除,即自杀的人
    
    if __name__ == '__main__':
        ysf(41,3) # 输出的是自杀的顺序。最后两个是16和31,说明这两个位置可以保证他俩的安全。

    原blog地址:https://blog.csdn.net/happyrocking/article/details/80058623

  • 相关阅读:
    点击新闻弹出新闻内容,并且新闻内容根据鼠标移动
    阻止用户复制页面上的文字的几种方法
    js简易聊天框- 鼠标和回车键发送消息
    Java——package和import关键字
    Java——static关键字
    Java——单例模式初步
    Java——this关键字
    Java面向对象的特征一:封装性
    Java再谈方法
    Java——对象
  • 原文地址:https://www.cnblogs.com/cassielcode/p/12705032.html
Copyright © 2011-2022 走看看