热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

NowCoder基础算法第三章:栈与队列的实现

本章探讨了使用固定数组实现栈和队列的基本方法,以及如何通过这些基本结构来实现更复杂的操作,如获取栈中的最小值。此外,还介绍了如何利用栈来模拟队列的行为,反之亦然。

使用固定数组实现栈与队列

栈和队列是两种基本的数据结构,它们可以通过固定大小的数组来高效地实现。对于栈而言,主要通过维护一个指向栈顶位置的索引来完成元素的入栈和出栈操作。当需要添加新元素时,将其放置在当前栈顶索引处,随后索引加一;移除元素时,索引减一即可。

栈的实现代码示例:

class Stack(object):
def __init__(self, capacity=10):
self.top = -1 # top初始化为-1,表示空栈
self.capacity = capacity
self.array = [None] * self.capacity
def push(self, item):
if self.top self.top += 1
self.array[self.top] = item
else:
raise Exception('Stack Overflow')
def pop(self):
if self.top >= 0:
item = self.array[self.top]
self.top -= 1
return item
else:
raise Exception('Stack Underflow')

对于队列,我们同样可以使用固定大小的数组来实现,但需要维护两个指针,分别指向队列的头部和尾部。入队时,在尾部添加元素并移动尾部指针;出队时,从头部移除元素并移动头部指针。

队列的实现代码示例:

class Queue(object):
def __init__(self, capacity=10):
self.frOnt= 0 # 队首指针
self.rear = 0 # 队尾指针
self.capacity = capacity
self.array = [None] * self.capacity
def enqueue(self, item):
if (self.rear + 1) % self.capacity != self.front:
self.array[self.rear] = item
self.rear = (self.rear + 1) % self.capacity
else:
raise Exception('Queue Overflow')
def dequeue(self):
if self.front != self.rear:
item = self.array[self.front]
self.frOnt= (self.front + 1) % self.capacity
return item
else:
raise Exception('Queue Underflow')

实现支持获取最小值的栈

为了实现一个能够快速获取最小值的栈,我们可以采用双栈策略。其中一个栈用于存储所有元素,另一个栈则用于跟踪当前最小值。每当有新元素加入主栈时,如果该元素小于或等于辅助栈的栈顶元素(即当前最小值),则同时将其压入辅助栈。这样,辅助栈的栈顶始终代表主栈中的最小值。

支持获取最小值的栈实现代码示例:

class MinStack(object):
def __init__(self):
self.main_stack = []
self.min_stack = []
def push(self, x):
self.main_stack.append(x)
if not self.min_stack or x <= self.min_stack[-1]:
self.min_stack.append(x)
def pop(self):
if self.main_stack:
if self.main_stack[-1] == self.min_stack[-1]:
self.min_stack.pop()
return self.main_stack.pop()
else:
raise Exception('Stack is empty')
def top(self):
if self.main_stack:
return self.main_stack[-1]
else:
raise Exception('Stack is empty')
def getMin(self):
if self.min_stack:
return self.min_stack[-1]
else:
raise Exception('Stack is empty')

使用栈和队列互相实现

除了直接实现栈和队列外,我们还可以探索如何使用一种数据结构来模拟另一种。例如,使用两个栈可以实现一个队列的功能,反之,使用两个队列也可以实现一个栈的功能。

使用两个栈实现队列:

class QueueUsingStacks(object):
def __init__(self):
self.in_stack = []
self.out_stack = []
def enqueue(self, item):
self.in_stack.append(item)
def dequeue(self):
if not self.out_stack:
while self.in_stack:
self.out_stack.append(self.in_stack.pop())
if self.out_stack:
return self.out_stack.pop()
else:
raise Exception('Queue is empty')

使用两个队列实现栈:

class StackUsingQueues(object):
def __init__(self):
self.queue1 = []
self.queue2 = []
def push(self, item):
self.queue1.append(item)
def pop(self):
if not self.queue1 and not self.queue2:
raise Exception('Stack is empty')
while len(self.queue1) > 1:
self.queue2.append(self.queue1.pop(0))
last_element = self.queue1.pop(0)
# Swap the names of queue1 and queue2 for the next operation
self.queue1, self.queue2 = self.queue2, self.queue1
return last_element


推荐阅读
  • 本文档旨在帮助开发者回顾游戏开发中的人工智能技术,涵盖移动算法、群聚行为、路径规划、脚本AI、有限状态机、模糊逻辑、规则式AI、概率论与贝叶斯技术、神经网络及遗传算法等内容。 ... [详细]
  • [Head First设计模式笔记]命令模式
    命令模式定义:将“请求”封装成对象,以便使用不同的请求、队列或者日志来参数化其他对象。命令模式也支持可撤销的操作。类图:适用设计方案举例:实现一种遥控器,该遥控器具有七个可编程的插 ... [详细]
  • 本文总结了MySQL的一些实用技巧,包括查询版本、修改字段属性、添加自动增长字段、备份与恢复数据库等操作,并提供了一些常见的SQL语句示例。 ... [详细]
  • 本文介绍了一种SQL查询方法,用于将表中的行数据转换为列显示,特别是当需要根据特定条件聚合不同字段的数据时。通过使用子查询和GROUP BY语句,可以有效地实现这一转换。 ... [详细]
  • VMware Horizon View 5.0桌面虚拟化部署实践与心得
    在近期的研究中,我花费了大约两天时间成功部署了桌面虚拟化环境,并在此过程中积累了一些宝贵的经验。本文将分享这些经验和部署细节,希望能对同样关注桌面虚拟化的同行有所帮助。 ... [详细]
  • Python编码入门指南
    本文探讨了使用Python进行网络设备连通性测试的简便性,特别是针对IP地址范围为192.168.0.101至192.168.0.200的设备。通过比较Python与Shell、Java等语言,展示了Python在执行此类任务时的优势。 ... [详细]
  • 本文详细介绍了在 Ubuntu 16.04 系统中使用 APT-GET 包管理器安装 MySQL 5.7 数据库的过程,并对安装后的文件和目录结构进行了说明,包括重要的配置文件及其功能。 ... [详细]
  • Node.js 入门指南(一)
    本文介绍了Node.js的安装步骤、如何创建第一个应用程序、NPM的基本使用以及处理回调函数的方法。通过实际操作示例,帮助初学者快速掌握Node.js的基础知识。 ... [详细]
  • 本文探讨了随着并发需求的增长,MySQL数据库架构如何从简单的单一实例发展到复杂的分布式系统,以及每一步演进背后的原理和技术解决方案。 ... [详细]
  • Photoshop打造炫酷金色锈迹立体文字
    本文介绍如何使用Photoshop创建具有金属质感和锈迹效果的立体文字。通过叠加多个带有特定图层样式的文字图层,结合火焰背景,营造出独特的视觉冲击力。 ... [详细]
  • 本文介绍了一种高效的方法来计算特定月份内的工作日数量,并提供了一段SQL代码示例,该方法通过优化减少了不必要的循环,提高了查询效率。 ... [详细]
  • 在Kubernetes集群中部署Kuboard
    本文详细介绍了如何在Kubernetes(简称k8s)环境中部署Kuboard,包括必要的命令和步骤,帮助用户顺利完成安装。 ... [详细]
  • 本文介绍了两种获取和研究 .NET Framework 源代码的有效途径:一是通过官方提供的下载链接获取完整源代码,并使用 Visual Studio 进行本地查看;二是利用在线资源平台,直接在网页上浏览源代码。 ... [详细]
  • 本文介绍了如何使用Gradle和gdx-setup.jar工具来创建LibGDX项目,包括详细的步骤和注意事项,适合初学者和有经验的开发者。 ... [详细]
  • MyEclipse技巧:高效生成toString方法
    本文将介绍如何在MyEclipse中快速且高效地生成toString方法,帮助开发者简化编码过程,提高开发效率。 ... [详细]
author-avatar
b01453901
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有