java 数据结构与算法---栈
2018-06-18 01:02:14来源:未知 阅读 ()
原理来自百度百科
一、栈的定义
栈是一种只能在一端进行插入和删除操作的特殊线性表;它按照先进后出的原则存储数据,先进入的数据被压入栈底,最后的数据在栈顶,需要读数据的时候从栈顶开始弹出数据(最后一个数据被第一个读出来);栈具有记忆作用,对栈的插入与删除操作中,不需要改变栈底指针;插入一般称为进栈(PUSH),删除则称为退栈(POP)。
二、栈的实现
package com.jalja.org.arith; public class MyStack<E>{ private Object [] arr;//存储 private int index;//栈元素实际入栈索引 private int maxSize;//栈的最大空间 private MyStack(int maxSize) { this.arr=new Object[maxSize]; this.index=0; this.maxSize=maxSize; } //入栈 public void push(E e) { if(isFull()) { throw new RuntimeException("myStack is full "); } arr[index++]=e; } //出栈 public E pop() { if(isNull()) { throw new RuntimeException("myStack is null "); } E e=(E)arr[--index]; return e; } //访问栈顶元素 public E peek() { return (E)arr[index-1]; } //栈是否为空 public boolean isNull() { return this.index <= 0; } //栈是否满了 public boolean isFull() { return index>=maxSize; } public static void main(String[] args) { MyStack<String> myStack=new MyStack(3); myStack.push("A0"); myStack.push("A1"); myStack.push("A2"); System.out.println(myStack.peek()); while(!myStack.isNull()) { System.out.println(myStack.pop()); } } }
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- 国外程序员整理的Java资源大全(全部是干货) 2020-06-12
- 2020年深圳中国平安各部门Java中级面试真题合集(附答案) 2020-06-11
- 2020年java就业前景 2020-06-11
- 04.Java基础语法 2020-06-11
- DES/3DES/AES 三种对称加密算法实现 2020-06-11
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash