顺序栈--Java实现
/*栈和队列:逻辑结构属于操作受限的线性表
*栈:特点先进后出,只允许在栈顶操作
*栈的实现方式:顺序栈和链栈
*常见的操作:进栈,出栈,获取栈顶,判空,判满,栈的容量
*栈的应用
*1.逆序相关操作
*2.分隔符匹配
* */
//顺序栈
public class MyStack {
private long[] arr;
private int maxSize;//栈的容量
private int top;//栈顶指针 public MyStack(int s) {
maxSize = s;
arr = new long[maxSize];
top = -1;
} public boolean isFull(){
return top == maxSize - 1;
} public boolean isEmpty(){
return top == -1;
} //进栈必须先判断满了吗
public void push(long key){
if(!isFull()){
arr[++top] = key;
}
} //出栈前判断是否为空
public long pop(){
long num = 0;
if(!isEmpty()){
num = arr[top--];
}
return num;
} //得到栈顶元素
public long getPeek(){
return arr[top];
} //显示栈的元素
public void diaplayStack(){
for(int i = top;i >= 0; i--){
System.out.print(arr[i] + " ");
}
System.out.println();
} public int size(){
return top + 1;
} public long getPeekN(int n){
return arr[n];
} public void displayStack(String s){
System.out.println(s);
System.out.println("stack----bottom to top");
for(int i = 0; i < size(); i++){
System.out.print(getPeekN(i) + " ");
}
System.out.println();
} }
顺序栈--Java实现的更多相关文章
- 数据结构Java实现05----栈:顺序栈和链式堆栈
		
一.堆栈的基本概念: 堆栈(也简称作栈)是一种特殊的线性表,堆栈的数据元素以及数据元素间的逻辑关系和线性表完全相同,其差别是线性表允许在任意位置进行插入和删除操作,而堆栈只允许在固定一端进行插入和删除 ...
 - [Java算法分析与设计]--顺序栈的实现
		
在程序的世界,栈的应用是相当广泛的.其后进先出的特性,我们可以应用到诸如计算.遍历.代码格式校对等各个方面.但是你知道栈的底层是怎么实现的吗?现在跟随本篇文章我们来一睹它的庐山真面目吧. 首先我们先定 ...
 - 数据结构——Java实现顺序栈
		
一.分析 栈是限定仅在表的一端进行插入或删除操作的线性表,对于栈来说,操作端称为栈顶,另一端则称为栈底,栈的修改是按照后进先出的原则进行的,因此又称为后进先出的线性表. 顺序栈是指利用顺序存储结构实现 ...
 - 数据结构Java实现03----栈:顺序栈和链式堆栈
		
一.堆栈的基本概念: 堆栈(也简称作栈)是一种特殊的线性表,堆栈的数据元素以及数据元素间的逻辑关系和线性表完全相同,其差别是线性表允许在任意位置进行插入和删除操作,而堆栈只允许在固定一端进行插入和删除 ...
 - 使用JAVA数组实现顺序栈
		
1,首先总结一下线性表(分为顺序表和链接表,[即顺序存储结构和链式存储结构的区别])和栈(顺序栈和链接栈)还有队列(顺序队列和链接队列)的JAVA类库中的实现: java.util.ArrayList ...
 - java 实现简单的顺序栈
		
package com.my; import java.util.Arrays; /** * 顺序栈 * @author wanjn * */ public class ArrayStack { pr ...
 - Java栈之顺序栈存储结构实现
		
一.栈的基本定义 栈是一种数据结构,它代表一种特殊的线性表,这种线性表只能在固定一端(通常认为是线性表的尾端)进行插入.删除操作的特殊线性表,通常就是在线性表的尾端进行插入.删除操作. 二.顺序栈的实 ...
 - 顺序栈,链栈,队列java实现
		
顺序栈 /** * 顺序栈 * */ public class SqStack { //栈的大小 private int maxSize; //栈顶指针 private int top; privat ...
 - Java的顺序栈和链式栈
		
栈的定义 栈是限制在表的一段进行插入和删除的运算的线性表,通常能够将插入.删除的一端为栈顶,例外一端称为栈底,当表中没有任何元素的时候称为空栈. 通常删除(又称"退栈")叫做弹出p ...
 
随机推荐
- JAVA课程设计 刘舒婷 201521123096
			
1.团队课程设计博客链接 2.个人负责模块说明 2.1 界面菜单的设计: 2.2 录入学生信息: 2.3 对已录入的学生信息进行修改: 3.个人代码提交记录截图 4.自己负责模块或任务详细说明 4.1 ...
 - 201521123087《Java程序设计》第14周学习总结
			
1. 本周学习总结 2. 书面作业 1. MySQL数据库基本操作 建立数据库,将自己的姓名.学号作为一条记录插入.(截图,需出现自己的学号.姓名)在自己建立的数据库上执行常见SQL语句(截图)-参考 ...
 - 杭电acm-2007平方和立方和
			
#include<stdio.h>int main(){ int t,m,n,x,y,i; while(scanf("%d%d",&n, ...
 - 第二部分----CSS的基础语法
			
PART-1 CSS的基础常识 一.什么是CSS? W3C标准中,倡导有3:其一为内容与表现分离,其二为内容与行为分离,其三为内容结构的语义化.其倡导中第一条的"表现"指的便可以说 ...
 - 关于学习Python的一些心得
			
1.关注函数参数的类型,如列表,字符串,int,而不是关注函数的功能 2.导入模块numpy,dir(numpy) 查看所有属性 3.''.join(列表) 将列表拆成字符串
 - 小甲鱼:Python学习笔记002_数组_元组_字符串
			
创建普通数组 >>> member=["山东黄金","九阳股份"] >>> member ['山东黄金', '九阳股份'] ...
 - SpringSecurity  登录  - 以及Md5加密
			
我们现在开放一个链接给其他系统,来访问我们的系统 http://localhost:8080/hulk-teller-web/haihui!init.jspa?loginId=teller01& ...
 - 利用ADO让普通人用excel读取oracle数据库表的通用办法
			
Ref:http://blog.csdn.net/iamlaosong/article/details/8465177 Excel通过ADO方式连接到Oracle并操作Oracle给那些编程能力不强的 ...
 - ②jquery复习
			
# jQuery 复习--by 传智前端与移动开发学院 ## 1. jQuery是什么?(了解)+ www.github.com+ jQuery 其实就是一堆的js函数,是普通的js,只不过应用广泛, ...
 - css控制div强制换行
			
div{white-space:nowrap;} 自动换行 div{ word-wrap: break-word; word-break: normal; } 强制英文单词断行 div{word-br ...