IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> 剑指offer—包含min函数的栈 -> 正文阅读

[Python知识库]剑指offer—包含min函数的栈

题目: 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数,并且调用 min函数、push函数 及 pop函数的
时间复杂度都是 O(1)
push(value):将value压入栈中
pop():弹出栈顶元素 top():获取栈顶元素
min():获取栈中最小元素

这个题目的话,我用我这空荡荡的的脑子想出了简单的代码,省时省力,哈哈哈
下面这个是我自己写的,一个函数一行代码,但是这个写法运行的时间较其他方法更长

class Solution:  # 自己写的,简单易懂
    def __init__(self):
        self.stack = []

    def push(self, node):
        self.stack.append(node)

    def pop(self):
        self.stack.pop()

    def top(self):
        return self.stack[-1]

    def min(self):
        return min(self.stack)

??下面这个方法是大佬用Java写的,我改成python的了,不知道对不对,反正提交是正确的,那就假装它是对的
??这个方法的思路很巧妙,利用最小值和存储的数字的差值来记录最小值,我自己加了一些注释

class Solution:
    def __init__(self):
        self.stack = []
        self.top_ = None
        self.min_ = None

    def push(self, node):  # 入栈操作
        if not self.stack:  # 第一次入栈比较特殊,入栈即为最小
            self.min_ = node
        self.stack.append(node - self.min_)  # 将即将入栈的元素和最小值min相减,将差值入栈
        if node < self.min_:  # 即将入栈的元素如果比当前的min值小,那么替换min值
            self.min_ = node
        self.top_ = node  # 更新栈顶的元素

    def pop(self):  # 出栈操作
        if self.stack:  # 当栈中有元素的时候
            if self.stack[-1] < 0:  # 如果栈顶存储的差值是负数,那么就说明即将要出栈的值是最小值min
                self.min_ -= self.stack[-1]  # 更新当前的最小值
            self.stack.pop()  # 弹出
        if self.stack:  # 当弹出栈顶元素以后,栈中还有元素时
            if self.stack[-1] > 0:  # 如果栈顶元素是正数,那么说明现在的栈顶元素不是最小值
                self.top_ = self.stack[
                    -1] + self.min_  # 那么正常使用差值加最小值求出栈顶本来的元素即可
            else:  # 如果栈顶不是正数,那么说明此时栈顶的元素为当前的最小值
                self.top_ = self.min_

    def top(self):
        return self.top_

    def min(self):
        print(self.min_)
        return self.min_

相对上一种方法来说,下面这个方法就简单易懂了,但是本来的代码写的很烂,稍稍改了一下,在push函数中,if判断语句后本来的顺序是if min>node or not min,这么一来当第一次添加数据的时候就会出错,因为min本来不存在,所以在判断第一个条件的时候程序就因为异常而退出了,并不会进入not min的判断中。但如果更换两者的顺序if not min or min > node,那么就会先判断not min,min如果不存在,那么not min就为真,进入循环。
??这里小扯一下,if的判断时,先以if A or B为例,如果条件A成立,那么if不会去判断条件B是否成立,if成立;反之则去判断条件B,如果条件B成立,if才成立。
??if A and B同理,当条件A为假的时候,计算机不会再去判断条件B了,if直接就不成立;反之,再去判断条件B,如果条件B成立,则if成立。

class Solution():  # 借助临时的数组来存储最小的值
    def __init__(self):
        self.stack = []# 存储元素的普通栈
        self.auxiliary = []# 存储最小值的数组,栈顶的元素是stack里的最小值

    def push(self, node):
        min = self.min()# 直接将当前对象的最小值利用自带的函数求出来
        if not min or min > node:# 当min不存在(输入第一个数的时候)或输入的值比当前对象的最小值还小的时候
            self.stack.append(node)# 将值入栈
            self.auxiliary.append(node)# 将值放入最小值的栈
        else:# 如果输入的值不是最小的值,那么只添加进普通的栈
            self.stack.append(node)

    def pop(self):
        if self.stack:# 当栈中有元素的时候
            if self.stack[-1] == self.auxiliary[-1]:# 如果即将要弹出栈的值是最小值,那么下面两个栈同时弹出
                self.stack.pop()
                self.auxiliary.pop()
            else:# 弹出的不是最小值时,只弹出普通栈的元素
                self.stack.pop()

    def top(self):
        if self.stack:
            return self.stack[-1]# 返回普通栈的栈顶元素

    def min(self):
        if self.auxiliary:
            return self.auxiliary[-1]# 返回栈顶元素
  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2021-09-29 10:12:29  更:2021-09-29 10:14:52 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/12 3:56:55-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码