【Java数据结构】栈

简介:

栈(stack)又名堆栈,它是一种运算受限的线性表。其限制是仅允许在表的一端进行插入和删除运算。这一端被称为栈顶,相对地,把另一端称为栈底。向一个栈插入新元素又称作进栈、入栈或压栈,它是把新元素放到栈顶元素的上面,使之成为新的栈顶元素;从一个栈删除元素又称作出栈或退栈,它是把栈顶元素删除掉,使其相邻的元素成为新的栈顶元素。


一个char的栈模型类:

package cn.deu;

public class CharStack {
    private int MaxSize;
    private char arr[];
    private int top;
    
    //构造方法
	public CharStack(int maxSize) {
		MaxSize = maxSize;
		arr=new char[MaxSize];
		top=-1;
	}
    
	//入栈
	public void push(char n){
		arr[++top]=n;
	}
	
	//出栈
	public char pop(){
		return arr[top--];
	}
	
	//站是否为空
	public boolean isEmpty(){
		return (top==-1);
	}
	
	//栈是否满
	public boolean isFull(){
		return (top==MaxSize-1);
	}
}

栈实例测试

package en.edu.Test;

import cn.deu.MyStack;

public class StackTest {


	public static void main(String[] args) {
         MyStack ms=new MyStack(10);
         
         ms.push(40);
         ms.push(30);
         ms.push(20);
         ms.push(10);
         ms.push(-10);
         ms.push(-20);
         
         while(!ms.isEmpty()){
        	 System.out.println(ms.pop());
         }
	}


}

结果:
-20
-10
10
20
30
40


应用:

用栈结构来实现单词逆序:

package cn.deu;

public class Reverse {
   private String input;

   public Reverse(String input) {
	this.input = input;
   }
   
   public String doReverse(){
	   CharStack cs=new CharStack(input.length());
	   for (int i = 0; i < input.length(); i++) {
		char ch=input.charAt(i);
		cs.push(ch);
	   }
	   String output="";
	   while(!cs.isEmpty()){
		   char ch=cs.pop();
		   output+=ch;
	   }
	   return output;
	   
   }
   
}

转载请注明出处:http://blog.csdn.net/acmman/article/details/50540662

相关文章
|
7天前
|
消息中间件 存储 搜索推荐
深入理解栈和队列(二):队列
深入理解栈和队列(二):队列
23 0
|
1月前
【栈】数据结构栈的实现
【栈】数据结构栈的实现
|
1月前
|
存储
数据结构--栈和队列
数据结构--栈和队列
|
1月前
|
算法 搜索推荐 Java
数据结构与算法(Java篇)笔记--希尔排序
数据结构与算法(Java篇)笔记--希尔排序
|
1月前
|
存储 算法 数据处理
数据结构从入门到精通——栈
栈,作为一种后进先出(LIFO)的数据结构,在计算机科学中扮演着重要的角色。它的特性使得它在处理函数调用、括号匹配、表达式求值等问题时具有得天独厚的优势。然而,如果我们跳出传统思维的束缚,会发现栈的用途远不止于此。
48 0
|
19天前
|
存储 算法 Java
Java数据结构与算法-java数据结构与算法(二)
Java数据结构与算法-java数据结构与算法
60 1
|
3天前
|
Java API
编码的奇迹:Java 21引入有序集合,数据结构再进化
编码的奇迹:Java 21引入有序集合,数据结构再进化
13 0
|
16天前
|
存储
【数据结构】什么是栈?
【数据结构】什么是栈?
24 0
【数据结构】什么是栈?
|
19天前
|
XML 存储 算法
Java数据结构与算法-java数据结构与算法(五)
Java数据结构与算法-java数据结构与算法
47 0
|
20天前
|
存储 设计模式 算法
【C/C++ 数据结构 线性表】深入理解与实现栈:从基础到应用的全面探索
【C/C++ 数据结构 线性表】深入理解与实现栈:从基础到应用的全面探索
52 0