【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

时间: 2024-08-01 16:44:21

【Java数据结构】栈的相关文章

数据结构――栈、队列和树(Java)

数据|数据结构 数据结构――栈.队列和树 开发者可以使用数组与链表的变体来建立更为复杂的数据结构.本节探究三种这样的数据结构:栈.队列与树.当给出算法时,出于简练,直接用Java代码. 栈 栈是这样一个数据结构,其数据项的插入和删除(获取)都只能在称为栈顶的一端完成.因为最后插入的数据项就是最先要删除的数据项,开发者往往将栈称为LILO(last-in, first-out)数据结构. 数据项压入(插入)或者弹出(删除或取得)栈顶.图13示例了一个有三个String数据项的栈,每个数据项压入栈顶

JAVA数据结构系列 栈

java数据结构系列之栈 手写栈 1.利用链表做出栈,因为栈的特殊,插入删除操作都是在栈顶进行,链表不用担心栈的长度,所以链表再合适不过了,非常好用,不过它在插入和删除元素的时候,速度比数组栈慢,因为它要维护自己的指针(Next)引用. package com.rsc.stack; import java.util.LinkedList; /** * 利用链表实现的栈 * @author 落雨 * http://ae6623.cn * @param <T> */ public class Li

java数据结构与算法之双向循环队列的数组实现方法_java

本文实例讲述了java数据结构与算法之双向循环队列的数组实现方法.分享给大家供大家参考,具体如下: 需要说明的是此算法我并没有测试过,这里给出的相当于伪代码的算法思想,所以只能用来作为参考! package source; public class Deque { private int maxSize; private int left; private int right; private int nItems; private long[] myDeque; //constructor p

关于数据结构栈的赋值

问题描述 关于数据结构栈的赋值 #include using namespace std; typedef int SElemType; //???????????????ù???????? #define STACK_INIT_SIZE 100 //?¨???????????±??×??ó?? #define STACKINCREMENT 10 //?¨???????????????????????ó?? typedef struct{ SElemType *base; //?¨???á???

PHP SPL标准库之数据结构栈(SplStack)介绍

  这篇文章主要介绍了PHP SPL标准库之数据结构栈(SplStack)介绍,栈(Stack)是一种特殊的线性表,因为它只能在线性表的一端进行插入或删除元素(即进栈和出栈),需要的朋友可以参考下 栈(Stack)是一种特殊的线性表,因为它只能在线性表的一端进行插入或删除元素(即进栈和出栈) SplStack就是继承双链表(SplDoublyLinkedList)实现栈. 类摘要如下: 简单使用如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18

数据结构 栈的基本操作 进制转换 为什么运行后会陷入死循环

问题描述 数据结构 栈的基本操作 进制转换 为什么运行后会陷入死循环 ```#include #include #include #define OK 1 #define ERROR -1 #define OVERFLOW -1 #define ENDFLAG 0 #define STACK_INIT_SIZE 100//初始分配量 #define STACKINCREMENT 10//增量 typedef int Status; typedef int SElemType; typedef s

PHP SPL标准库之数据结构栈(SplStack)介绍_php实例

栈(Stack)是一种特殊的线性表,因为它只能在线性表的一端进行插入或删除元素(即进栈和出栈) SplStack就是继承双链表(SplDoublyLinkedList)实现栈. 类摘要如下: 简单使用如下: //把栈想象成一个颠倒的数组 $stack = new SplStack(); /** * 可见栈和双链表的区别就是IteratorMode改变了而已,栈的IteratorMode只能为: * (1)SplDoublyLinkedList::IT_MODE_LIFO | SplDoublyL

c++-数据结构 栈的定义 栈的定义

问题描述 数据结构 栈的定义 栈的定义 定义:栈是限定仅在表头进行插入和删除操作的线性表. 栈定义用的是数组 那为什么只能在头插入和删除 实际上到底什么啊 解决方案 只能在栈顶操作只是栈的定义要求是这样的,这样就实现了"先进后出"的效果.你应该发现普通链表.栈.队列这三种结构本质是相同的,只是人为规定只能在一端或者两端操作. 你如果直接对栈底进行操作,当然是可以的,只是这种数据结构已经不能称之为"栈"了. 如果从编程角度来说的话,假设栈是一个类,那么这个类只提供了p

帮忙写个数据结构栈的 谢谢

问题描述 帮忙写个数据结构栈的 谢谢 1.从键盘上输入表达式. 2.分析该表达式是否合法: (1)是数字,则判断该数字的合法性.若合法,则压入数据到堆栈中. (2)是规定的运算符,则根据规则进行处理.在处理过程中,将计算该表达式的值. (3)若是其它字符,则返回错误信息. 3.若上述处理过程中没有发现错误,则认为该表达式合法,并打印处理结果. 解决方案 http://wenku.baidu.com/link?url=UQoesURrEsUM4NvE5ZacHn8kAk5HgZTj5uMfmZEg

数据结构栈的出栈入栈的指针问题

问题描述 数据结构栈的出栈入栈的指针问题 入栈时,top指针是 s.top++=e 还是s.++top=e? 出栈时,top指针是 s.top--=e 还是s.--top=e? 还有就是 top指针是指向栈顶元素or栈顶元素下一位置? 解决方案 入栈操作需要先将top指针自增,然后新的top位置的值为入栈的值,先加后用,应该是s.++top=e; 出栈时先获取栈顶元素,然后将栈顶指针减一,所以是先用后减,即s.top--=e; 主要是++的位置,++top,在前先加后用:top++在后先用后加: