python如何使用数组实现栈
发表于:2025-12-05 作者:千家信息网编辑
千家信息网最后更新 2025年12月05日,小编给大家分享一下python如何使用数组实现栈,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!使用数组实现栈自己实现一个栈
千家信息网最后更新 2025年12月05日python如何使用数组实现栈
小编给大家分享一下python如何使用数组实现栈,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
使用数组实现栈
自己实现一个栈,要求这个栈具有push()、pop()(返回栈顶元素并出栈)、peek() (返回栈顶元素不出栈)、isEmpty()、size()这些基本的方法。
提示:每次入栈之前先判断栈的容量是否够用,如果不够用就用Arrays.copyOf()进行扩容;
public class MyStack {private int[] storage;//存放栈中元素的数组private int capacity;//栈的容量private int count;//栈中元素数量private static final int GROW_FACTOR = 2;//TODO:不带初始容量的构造方法。默认容量为8public MyStack() {this.capacity = 8;this.storage=new int[8];this.count = 0;}//TODO:带初始容量的构造方法public MyStack(int initialCapacity) {if (initialCapacity < 1)throw new IllegalArgumentException("Capacity too small.");this.capacity = initialCapacity;this.storage = new int[initialCapacity];this.count = 0;}//TODO:入栈public void push(int value) {if (count == capacity) {ensureCapacity();}storage[count++] = value;}//TODO:确保容量大小private void ensureCapacity() {int newCapacity = capacity * GROW_FACTOR;storage = Arrays.copyOf(storage, newCapacity);capacity = newCapacity;}//TODO:返回栈顶元素并出栈private int pop() {count--;if (count == -1)throw new IllegalArgumentException("Stack is empty.");return storage[count];}//TODO:返回栈顶元素不出栈private int peek() {if (count == 0){throw new IllegalArgumentException("Stack is empty.");}else {return storage[count-1];}}//TODO:判断栈是否为空private boolean isEmpty() {return count == 0;}//TODO:返回栈中元素的个数private int size() {return count;}}
验证:
MyStack myStack = new MyStack(3);myStack.push(1);myStack.push(2);myStack.push(3);myStack.push(4);myStack.push(5);myStack.push(6);myStack.push(7);myStack.push(8);System.out.println(myStack.peek());//8System.out.println(myStack.size());//8for (int i = 0; i < 8; i++) { System.out.println(myStack.pop());}System.out.println(myStack.isEmpty());//truemyStack.pop();//报错:java.lang.IllegalArgumentException: Stack is empty.以上是"python如何使用数组实现栈"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
元素
容量
数组
方法
篇文章
内容
并出
不够
不怎么
个数
够用
大小
大部分
数量
更多
知识
行业
资讯
资讯频道
频道
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
如何更改移动服务器发送地址
我的世界国家版服务器地址
数据库外部键是什么意思
大数据数据库首选
shein软件开发
参展商数据库建立系统
河北嵌入式软件开发哪家可靠
网络安全法与电信法
山东dns服务器
公司软件开发规划
从大数据的角度解读数据库
录像机和服务器时间不同步
飞书smtp服务器地址
中电太极十五所软件开发薪资
网络安全审计包括
sql 数据库备份还原
游戏软件开发工资
数据库采用的安全机制有哪些
学软件开发好还是U 好
信息网络安全黑板报插画
php数据库漏洞
阴阳师 服务器没了
服务器送邮箱
宝山区互联网软件开发市场报价
北京市京东网络技术
《网络安全法》考试答案
dayz 服务器管理
如何停止系统推荐服务器
剑三原号主知道你确定服务器
power750服务器怎么安装