因为工作需要,这两天就被部门boss,分了个新的任务,学习python。对于我来说挺难的,主要也不知道怎么才能有效的学,第一天就抱着本技术书死磕,跟着敲了一些基础代码(说实话,当天看了3,4个小时,感觉还是挺迷茫了,找不到方式,不知道重点学什么), 可能是我当天提交的日报以及提交的代码,也让boss看到了,第二天一到公司就明确的给我说,”今天,你用python实现堆栈(进栈、出栈、查看栈顶元素),和队列(入队、出队、遍历所有队列内容)“, 好家伙,目标来了,努力吧!!!


下面是代码,个人感觉,注释挺全乎的!
实现这个要求,你要先知道什么是栈???
栈(stack)是一种线性数据结构,就好像是盛放乒乓球的圆筒容器(一头密封,一头进出),也就是说先进入容器的乒乓球往往是最后被拿出的。
栈也一样,当中的元素只能先入后出(First In Last Out,简称FILO),而最早进入的元素存放的位置叫做栈底,最后进入的元素存放的位置叫做栈顶。
import self as self
"""
isEmpty 判断是否为空
push    添加新元素(及最后被添加的元素为栈顶)
pop     移出栈顶元素
peek    查看当前栈顶元素
size    计算数量
"""

class Stack:#创建一个栈
    def __init__(self):#初始为空栈
        self.items = []
    def isEmpty(self):
        return self.items ==[]
    def push(self, item):
        self.items.append(item) #添加新成员,新成员为顶,旧骨干为底
    def pop(self):
        return self.items.pop() #移出顶,底上位
    def peek(self):             #查看当前顶部成员
        return self.items[-1]
    def size(self):             #查看当前成员数量
        return len(self.items)


s = Stack()
print(s.isEmpty())

name = ["静","澜","李白","韩信"]
for n in name:
    s.push(n)

# s.push(666)
# s.push("静")
# s.push("李白")
# s.push("韩信")
print("未减员后的量:%d"%s.size())
print("未减员时的顶:"+s.peek())
print("被无情干掉的顶:"+s.pop())
print("已减员后的顶:"+s.peek())
print("已减员后的量:%d"%s.size())


当然这些代码也简单,但是boss却希望我不要使用原生,用最基础的数据结构去实现,所有自定义的第二版来了!!!


class Stack:
    """
    自定义一个栈
    """
    def __init__(self, size):
        self.size = size
        self.list = []  # 存放数据的列表
        self.top = 0  # 栈顶指针

    def push(self, element): #入栈
        if self.top >= self.size:
            print("栈已满!!!")
        self.list.insert(self.top, element)  # 放入元素
        self.top += 1  # 添加元素,栈顶指针向上加1

    def pop(self):  #出栈
        if self.top == 0:
            print("栈还空!!!")
        self.top -= 1  # 去除元素,栈顶指针向下减1
        element = self.list[self.top]
        self.list.remove(element)
        return element

    def peek(self):
        if self.top == 0:
            print("栈空,暂无栈顶元素!!!")
        element = self.list[-1]
        return element
    def size(self):             #查看当前成员数量
        return len(self.list)


s = Stack(4)  # 传入栈的长度

name = ["静","澜","李白","韩信"]
for n in name:
    s.push(n)
    print("曾经的顶端王者:", s.peek())
print("现在位于栈顶端的王者:",s.peek())
print("正在被干掉的顶端王者:",s.pop())
print(s.list)


虽然第二版比第一版复杂了点,但是还没到底boss的期望,那怎么办呢??? 继续沟通,继续奋斗呗!!!所以第三版它来了!!! 这是最终敲定版本,通过链表的节点的方式实现栈


class Node(object): ##节点,包括两个属性,一个是节点的值,一个是节点的下一个指向

    def __init__(self,value):

        self.value = value  #赋值给节点

        self.next = None    #节点的下一个指向


class Stack:
    """
    自定义一个栈
    """
    def __init__(self):
        self.top = None  #创建栈

    def push(self,node): #入栈
       if  node != None:
           packNode = Node(node) #实例化Node类
           packNode.next = self.top #新节点赋值给栈顶
           self.top = packNode
           return packNode.value #返回对于值
       else:
           return None #返回None


    def pop(self): #出栈
           if self.top == None: #判断是否为空
               return None
           else:
               tmp = self.top.value
               self.top = self.top.next #将栈顶指向变为目前栈顶的下一个节点
               return tmp #返回出栈的节点的值


    def peek(self):  # 查看栈顶元素
        if self.top != None:  # 判断栈顶是否为空,返回相应的元素
            return self.top.value
        else:
            return None

    def size(self):             #查看当前成员数量
        return len(self.list)


s = Stack()  # 传入栈的长度

name = ["静","澜","李白","韩信"]
for n in name:
    s.push(n)
    print("曾经的顶端王者:", s.peek())
print("现在位于栈顶端的王者:",s.peek())
print("正在被干掉的顶端王者:",s.pop())


还有就是入栈、出栈的时间复杂度都是O(1)


好了,结束!!!