Python实现队列,栈

通过python设计实现队列以及栈,复习一下数据结构

队列:先进先出

class Queue(object):
    def __init__(self,size):
        self.queue = []
        self.size = size

    def is_empty(self):
        if len(self.queue) == 0:
            return True
        else:
            return False

    def is_full(self):
        if len(self.queue) == self.size:
            return True
        else:
            return False

    def pop(self):
        if self.is_empty():
            raise Exception("QueueIsEmpty")
        else:
            top = self.queue[0]
            self.queue.remove(top)
            return top

    def pull(self,data):
        if self.is_full:
            raise Exception("QueueOverFlow")
        else:
            self.queue.append(data)

    def show(self):
        print self.queue```

栈:先进后出,pop弹出栈顶元素

class Stack(object):
def init(self,size=10):
self.stack = []
self.size = size
self.top = -1

def is_full(self):
    return self.top + 1 == 10

def is_empty(self):
    return self.top == -1

def push(self,data):
    if self.is_full():
        raise Exception("StackOverFlow")
    else:
        self.stack.append(data)
        self.top+=1

def pop(self):
    if self.is_empty():
        raise Exception("StackIsEmpty")
    else:
        self.stack.pop()
        self.top -=1

def top(self):
    if self.is_empty():
        raise Exception("StackIsEmpty")
    else:
        return self.stack[self.top]

def show(self):
    print self.stack
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 栈 栈的英文单词是Stack,它代表一种特殊的线性表,这种线性表只能在固定一端(通常认为是线性表的尾端)进行插入,...
    Jack921阅读 1,553评论 0 5
  • 一、栈 1.1 栈的实现 栈(Stack)是限制仅在表的一端进行插入和删除运算的线性表。java没有栈这样的数据结...
    yjaal阅读 1,476评论 0 1
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,024评论 25 709
  • 1.栈 1.1.栈的定义 栈(stack)是限定仅在表尾(栈顶 top)进行插入和删除操作的后进先出的线性表。 p...
    JonyFang阅读 1,436评论 0 21
  • 姓名:楼灵芝 单位:杭州熙林服饰 【日精进打卡第134天】 【知~学习】 《六项精进》背诵1遍,共570遍; 《大...
    心镜_8ef4阅读 159评论 0 0