鱼C论坛

 找回密码
 立即注册
查看: 2806|回复: 2

基于deque实现栈

[复制链接]
发表于 2023-4-9 22:53:04 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
基于deque实现栈的常用功能。然后以此实现一个十进制转八进制的转换算法。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-4-9 22:56:43 | 显示全部楼层
在Python中,我们可以使用collections模块中的deque数据结构实现栈。

首先,我们定义一个Stack类,实现栈的基本操作(如push, pop和peek等)。

然后,我们使用此栈实现一个十进制转八进制的转换算法。

  1. from collections import deque

  2. class Stack:
  3.     def __init__(self):
  4.         self.stack = deque()

  5.     def push(self, item):
  6.         self.stack.append(item)

  7.     def pop(self):
  8.         if not self.is_empty():
  9.             return self.stack.pop()
  10.         else:
  11.             raise IndexError("pop from an empty stack")

  12.     def peek(self):
  13.         if not self.is_empty():
  14.             return self.stack[-1]
  15.         else:
  16.             raise IndexError("peek at an empty stack")

  17.     def is_empty(self):
  18.         return len(self.stack) == 0

  19.     def size(self):
  20.         return len(self.stack)

  21. def decimal_to_octal(decimal_number):
  22.     stack = Stack()
  23.     while decimal_number > 0:
  24.         remainder = decimal_number % 8
  25.         stack.push(remainder)
  26.         decimal_number //= 8

  27.     octal_number = ""
  28.     while not stack.is_empty():
  29.         octal_number += str(stack.pop())

  30.     return octal_number

  31. if __name__ == "__main__":
  32.     decimal_number = int(input("请输入一个十进制数: "))
  33.     octal_number = decimal_to_octal(decimal_number)
  34.     print(f"十进制数 {decimal_number} 对应的八进制数为: {octal_number}")
复制代码


上述代码首先导入deque数据结构,并定义了一个Stack类,实现了基于deque的栈。

接下来,我们定义了一个名为decimal_to_octal的函数,它接受一个十进制数作为输入,使用栈将其转换为八进制数,并返回结果。

在主程序部分,我们获取用户输入的十进制数,调用decimal_to_octal函数进行转换,并打印结果。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-4-10 07:21:26 | 显示全部楼层


首先我们需要导入`collections`模块中的`deque`类:


  1. from collections import deque

  2. class Stack:
  3.     def __init__(self):
  4.         self.stack = deque()

  5.     def push(self, value):
  6.         self.stack.append(value)

  7.     def pop(self):
  8.         if not self.is_empty():
  9.             return self.stack.pop()
  10.         else:
  11.             return None

  12.     def peek(self):
  13.         if not self.is_empty():
  14.             return self.stack[-1]
  15.         else:
  16.             return None

  17.     def is_empty(self):
  18.         return len(self.stack) == 0

  19.     def size(self):
  20.         return len(self.stack)
复制代码


然后我们来实现一个十进制转八进制的转换算法,这个过程就是将一个十进制数除以8取余数,然后将余数依次存入栈中,最后将栈中的元素依次取出并连接起来即可。


  1. def decimal_to_octal(decimal):
  2.     stack = Stack()
  3.     while decimal > 0:
  4.         remainder = decimal % 8
  5.         stack.push(remainder)
  6.         decimal //= 8
  7.    
  8.     octal = ""
  9.     while not stack.is_empty():
  10.         octal += str(stack.pop())
  11.    
  12.     return octal
复制代码


这样,我们就实现了一个基于`deque`实现栈的常用功能,并且使用栈来实现了一个十进制转八进制的转换算法。
有用请设置最佳答案
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-24 18:06

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表