【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

相关文章
|
20小时前
|
存储 测试技术
【数据结构】操作受限的线性表,栈的具体实现
【数据结构】操作受限的线性表,栈的具体实现
11 5
|
1天前
|
存储 Java C++
Java虚拟机(JVM)管理内存划分为多个区域:程序计数器记录线程执行位置;虚拟机栈存储线程私有数据
Java虚拟机(JVM)管理内存划分为多个区域:程序计数器记录线程执行位置;虚拟机栈存储线程私有数据,如局部变量和操作数;本地方法栈支持native方法;堆存放所有线程的对象实例,由垃圾回收管理;方法区(在Java 8后变为元空间)存储类信息和常量;运行时常量池是方法区一部分,保存符号引用和常量;直接内存非JVM规范定义,手动管理,通过Buffer类使用。Java 8后,永久代被元空间取代,G1成为默认GC。
10 2
|
2天前
|
网络协议 Java 程序员
TCP/IP协议栈是网络通信基础,Java的`java.net`包提供工具,使开发者能利用TCP/IP创建网络应用
【6月更文挑战第23天】 **TCP/IP协议栈是网络通信基础,它包含应用层(HTTP, FTP等)、传输层(TCP, UDP)、网络层(IP)、数据链路层(帧, MAC地址)和物理层(硬件信号)。Java的`java.net`包提供工具,使开发者能利用TCP/IP创建网络应用,如Socket和ServerSocket用于客户端和服务器通信。**
9 3
|
1天前
|
算法
【C/数据结构和算法】:栈和队列
【C/数据结构和算法】:栈和队列
6 1
|
15小时前
|
存储 监控 算法
Java中的内存管理:从堆到栈的深入解析
Java中的内存管理:从堆到栈的深入解析
|
15小时前
|
存储 安全 Java
如何在Java中实现自定义数据结构:从头开始
如何在Java中实现自定义数据结构:从头开始
|
1天前
|
消息中间件 存储 缓存
Java中的数据结构与算法优化攻略
Java中的数据结构与算法优化攻略
|
1天前
|
算法 Java
Java数据结构与算法:位运算之位移操作
Java数据结构与算法:位运算之位移操作
|
1天前
|
存储 算法 Java
Java数据结构与算法:线性数据结构之数组
Java数据结构与算法:线性数据结构之数组
|
1天前
|
算法 Java
Java数据结构与算法:字符串匹配算法之暴力匹配
Java数据结构与算法:字符串匹配算法之暴力匹配