【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

相关文章
|
5天前
|
存储 算法 Java
Java面试题:深入探究Java内存模型与垃圾回收机制,解释JVM中堆内存和栈内存的主要区别,谈谈对Java垃圾回收机制的理解,Java中的内存泄漏及其产生原因,如何检测和解决内存泄漏问题
Java面试题:深入探究Java内存模型与垃圾回收机制,解释JVM中堆内存和栈内存的主要区别,谈谈对Java垃圾回收机制的理解,Java中的内存泄漏及其产生原因,如何检测和解决内存泄漏问题
11 0
|
5天前
|
存储 安全 Java
Java面试题:在JVM中,堆和栈有什么区别?请详细解释说明,要深入到底层知识
Java面试题:在JVM中,堆和栈有什么区别?请详细解释说明,要深入到底层知识
16 3
|
5天前
|
存储 缓存 监控
Java面试题:解释堆和栈的OutOfMemoryError通常在什么情况下会发生
Java面试题:解释堆和栈的OutOfMemoryError通常在什么情况下会发生
15 3
|
6天前
|
缓存 算法 安全
Java中的数据结构与算法优化策略
Java中的数据结构与算法优化策略
|
7天前
|
存储 Java
深入理解Java中的堆内存与栈内存分配
深入理解Java中的堆内存与栈内存分配
|
13天前
|
存储 Java
Java堆与栈的区别及应用
Java堆与栈的区别及应用
|
5天前
|
存储 设计模式 监控
Java面试题:简述JVM的内存结构,包括堆、栈、方法区等。栈内存优化的方法有 哪些?
Java面试题:简述JVM的内存结构,包括堆、栈、方法区等。栈内存优化的方法有 哪些?
15 0
|
5天前
|
Java 开发者
Java面试题:Java内存管理精要与多线程协同策略,Java内存管理:堆内存、栈内存、方法区、垃圾收集机制等,多线程编程的掌握,包括线程创建、同步机制的原理
Java面试题:Java内存管理精要与多线程协同策略,Java内存管理:堆内存、栈内存、方法区、垃圾收集机制等,多线程编程的掌握,包括线程创建、同步机制的原理
10 0
|
5天前
|
算法 Java 开发者
Java面试题:Java内存探秘与多线程并发实战,Java内存模型及分区:理解Java堆、栈、方法区等内存区域的作用,垃圾收集机制:掌握常见的垃圾收集算法及其优缺点
Java面试题:Java内存探秘与多线程并发实战,Java内存模型及分区:理解Java堆、栈、方法区等内存区域的作用,垃圾收集机制:掌握常见的垃圾收集算法及其优缺点
8 0
|
5天前
|
存储 算法 Java
Java面试题:解释JVM的内存结构,并描述堆、栈、方法区在内存结构中的角色和作用,Java中的多线程是如何实现的,Java垃圾回收机制的基本原理,并讨论常见的垃圾回收算法
Java面试题:解释JVM的内存结构,并描述堆、栈、方法区在内存结构中的角色和作用,Java中的多线程是如何实现的,Java垃圾回收机制的基本原理,并讨论常见的垃圾回收算法
7 0