一、栈

栈的定义 
栈(Stack)是限制仅在表的一端进行插入和删除运算的线性表。 
(1)通常称插入、删除的这一端为栈顶 (Top),另一端称为栈底 (Bottom)。 
(2)当表中没有元素时称为空栈。 
(3)栈为后进先出(Last In First Out)的线性表,简称为 LIFO 表。 
栈的修改是按后进先出的原则进行。每次删除(退栈)的总是当前栈中" 
最新"的元素,即最后插入(进栈)的元素,而最先插入的是被放在栈的底部, 
要到最后才能删除。

2、栈的基本运算

(1) 判断栈是否为空 
    boolean isEmpty();      
(2)清空栈 
    void clear();  
(3)栈的长度 
    int length();     
(4)数据入栈 
    boolean push(T data);   
 (5)数据出栈 ,栈中删除
    T pop();     
 (6)数据出栈 ,栈中不删除

T peek();

二、代码编写

1、接口类

  1. package com.lin.stack;
  2. /**
  3. * 功能概要:栈的接口类
  4. *
  5. * @author linbingwen
  6. * @since  2015年8月29日
  7. */
  8. public interface MyStack<T> {
  9. /**
  10. * 判断栈是否为空
  11. * @author linbingwen
  12. * @since  2015年8月29日
  13. * @return
  14. */
  15. boolean isEmpty();
  16. /**
  17. * 清空栈
  18. * @author linbingwen
  19. * @since  2015年8月29日
  20. */
  21. void clear();
  22. /**
  23. * 栈的长度
  24. * @author linbingwen
  25. * @since  2015年8月29日
  26. * @return
  27. */
  28. int length();
  29. /**
  30. * 数据入栈
  31. * @author linbingwen
  32. * @since  2015年8月29日
  33. * @param data
  34. * @return
  35. */
  36. boolean push(T data);
  37. /**
  38. * 数据出栈 ,栈中删除
  39. * @author linbingwen
  40. * @since  2015年8月29日
  41. * @return
  42. */
  43. T pop();
  44. /**
  45. * 数据出栈 ,栈中不删除
  46. * @author linbingwen
  47. * @since  2015年8月29日
  48. * @return
  49. */
  50. T peek();
  51. }

2、数组实现栈

  1. package com.lin.stack;
  2. /**
  3. * 功能概要:数组实现栈
  4. *
  5. * @author linbingwen
  6. * @since  2015年8月29日
  7. */
  8. public class MyArrayStack<T> implements MyStack<T> {
  9. private Object[] objs = new Object[16];
  10. private int size;
  11. @Override
  12. public boolean isEmpty() {
  13. return size == 0;
  14. }
  15. @Override
  16. public void clear() {
  17. for (int i = 0; i < objs.length; i++) {
  18. objs[i] = null;
  19. size--;
  20. }
  21. }
  22. @Override
  23. public int length() {
  24. return size;
  25. }
  26. @Override
  27. public boolean push(T data) {
  28. if(size == (objs.length-1)){
  29. Object[] temp = new Object[objs.length*2];
  30. for (int i = 0; i < objs.length; i++) {
  31. temp[i]=objs[i];
  32. }
  33. objs= temp;
  34. }
  35. objs[size++]=data;
  36. return true;
  37. }
  38. @Override
  39. @SuppressWarnings("unchecked")
  40. public T pop() {
  41. return size == 0?null:(T) objs[(size--)-1];
  42. }
  43. @Override
  44. @SuppressWarnings("unchecked")
  45. public T peek() {
  46. return size == 0?null:(T) objs[size];
  47. }
  48. }

3、链表实现栈

  1. package com.lin.stack;
  2. /**
  3. * 功能概要:
  4. *
  5. * @author linbingwen
  6. * @since  2015年8月29日
  7. */
  8. public class MyListStack<T> implements MyStack<T>{
  9. private int size;
  10. private Node top;
  11. class Node{
  12. T data;
  13. Node pre;
  14. }
  15. @Override
  16. public boolean isEmpty() {
  17. return size == 0;
  18. }
  19. @Override
  20. public void clear() {
  21. top = null;
  22. }
  23. @Override
  24. public int length() {
  25. return size;
  26. }
  27. @Override
  28. public boolean push(T data) {
  29. Node node = new Node();
  30. node.data=data;
  31. if( null == top){
  32. top = node;
  33. }else {
  34. node.pre = top;
  35. top =node;
  36. }
  37. size++;
  38. return true;
  39. }
  40. @Override
  41. public T pop() {
  42. if(size == 0){
  43. return null;
  44. }
  45. T data = top.data;
  46. top = top.pre;
  47. size--;
  48. return data;
  49. }
  50. @Override
  51. public T peek() {
  52. if(size == 0){
  53. return null;
  54. }
  55. T data = top.data;
  56. return data;
  57. }
  58. }

4、测试

  1. package com.lin.stack;
  2. /**
  3. * 功能概要:
  4. *
  5. * @author linbingwen
  6. * @since  2015年8月29日
  7. */
  8. public class StackTest {
  9. /**
  10. * @author linbingwen
  11. * @since  2015年8月29日
  12. * @param args
  13. */
  14. public static void main(String[] args) {
  15. MyStack<Integer> myStack1 = new MyArrayStack<Integer>();
  16. MyStack<Integer> myStack2 = new MyListStack<Integer>();
  17. for(int i =0;i<30;i++){
  18. myStack1.push(i);
  19. myStack2.push(i);
  20. }
  21. System.out.println("数组实现的栈输出如下 ");
  22. for(int j =0;j<30;j++){
  23. System.out.print(myStack1.pop()+"  ");
  24. }
  25. System.out.println();
  26. System.out.println("链表实现的栈输出如下 ");
  27. for(int k =0;k<30;k++){
  28. System.out.print(myStack2.pop()+"  ");
  29. }
  30. }
  31. }

输出结果如下:

或者 看这里:

数组实现的栈输出如下 
29  28  27  26  25  24  23  22  21  20  19  18  17  16  15  14  13  12  11  10  9  8  7  6  5  4  3  2  1  0  
链表实现的栈输出如下 
29  28  27  26  25  24  23  22  21  20  19  18  17  16  15  14  13  12  11  10  9  8  7  6  5  4  3  2  1  0 

http://blog.csdn.net/evankaka/article/details/48088983

Java栈的实例-数组和链表两种方法(转)的更多相关文章

  1. Java构造和解析Json数据的两种方法详解一——json-lib

    转自:http://www.cnblogs.com/lanxuezaipiao/archive/2013/05/23/3096001.html 在www.json.org上公布了很多JAVA下的jso ...

  2. Java构造和解析Json数据的两种方法详解二

    在www.json.org上公布了很多JAVA下的json构造和解析工具,其中org.json和json-lib比较简单,两者使用上差不多但还是有些区别.下面接着介绍用org.json构造和解析Jso ...

  3. Java构造和解析Json数据的两种方法详解二——org.json

    转自:http://www.cnblogs.com/lanxuezaipiao/archive/2013/05/24/3096437.html 在www.json.org上公布了很多JAVA下的jso ...

  4. Java执行shell脚本并返回结果两种方法的完整代码

    Java执行shell脚本并返回结果两种方法的完整代码 简单的是直接传入String字符串,这种不能执行echo 或者需要调用其他进程的命令(比如调用postfix发送邮件命令就不起作用) 执行复杂的 ...

  5. DES加密 java与.net可以相互加密解密两种方法

    DES加密 java与.net可以相互加密解密两种方法 https://www.cnblogs.com/DrWang/archive/2011/03/30/2000124.html sun.misc. ...

  6. PHP中数组合并的两种方法及区别介绍

    PHP数组合并两种方法及区别 如果是关联数组,如下: 复制代码代码如下: $a = array( 'where' => 'uid=1', 'order' => 'uid', ); $b = ...

  7. Eclipse将引用了第三方jar包的Java项目打包成jar文件的两种方法

    方案一:用Eclipse自带的Export功能 步骤1:准备主清单文件 “MANIFEST.MF”, 由于是打包引用了第三方jar包的Java项目,故需要自定义配置文件MANIFEST.MF,在该项目 ...

  8. 将引用了第三方jar包的Java项目打包成jar文件的两种方法

    方案一:用Eclipse自带的Export功能 步骤1:准备主清单文件 “MANIFEST.MF”, 由于是打包引用了第三方jar包的Java项目,故需要自定义配置文件MANIFEST.MF,在该项目 ...

  9. 使用 Eclipse 可视化插件 windowbuilder 进行Java GUI开发(插件安装的两种方法)

    对于Java GUI开发 其实最方便的方法是用插件制作,当然先了解完代码原理是最好的. eclispe安装windowbuilder有两种方式,一种是离线安装,一种是在线安装. 一.第一种在线安装: ...

随机推荐

  1. OGEngine教程:声音载入

    以下介绍声音资源从载入到播放的一个流程 首先,我们将须要的音频文件放到assets文件夹下,OGE中SoundRes和MusicRes为我们封装了非常多经常使用的方法,能够用于载入及播放等经常使用功能 ...

  2. Delphi基础Write写入结构体到文件(使用 file of myrecord就行了,真简单)

    program WriteStruct; {$APPTYPE CONSOLE} uses SysUtils; //写入结构体 type TCustomer = record ID: ]; Code: ...

  3. Delaunay三角剖分算法

    在图像处理中,经常会使用到三角剖分算法: 具体定义及其算法可以参考:http://baike.so.com/doc/5447649.html 下面放出来代码: Delaunay接口为存C: 测试是使用 ...

  4. [Android学习笔记]组合控件的使用

    组合控件的使用 开发过程中,多个UI控件需要协同工作,相互交互之后,才可完成一个完整的业务需求,此时可把这些控件封装成为一个整体,相互之间的交互逻辑封装其中,外部调用可无需关心内部逻辑,只需获取处理后 ...

  5. 小议common lisp程序开发流程 - Ever 17 - 博客频道 - CSDN.NET

    小议common lisp程序开发流程 - Ever 17 - 博客频道 - CSDN.NET 小议common lisp程序开发流程 分类: lisp 2011-04-17 20:59 1316人阅 ...

  6. Spring整合的quartz任务调度的实现方式

    一.在web.xml中将配置文件的位置指定好. Web.xml的配置如下: <?xmlversion="1.0"encoding="UTF-8"?> ...

  7. thinkphp中URL传参数的几种方式

    在thinkphp中,url传参合asp.net中原理类似,下面就单个参数和多个参数传递方式进行一个简单讲解 1.传单个参数 单个参数这种比较简单,例如 想像edit操作里面传递一个id值,如下写法_ ...

  8. JavaScript 中的事件流和事件处理程序(读书笔记思维导图)

    JavaScript 程序采用了异步事件驱动编程模型.在这种程序设计风格下,当文档.浏览器.元素或与之相关的对象发生某些有趣的事情时,Web 浏览器就会产生事件(event). JavaScript ...

  9. Android真机网络adb联机调试初探

    新项目是一个基于android4.2设备.刚拿到demo板时就对联机互调感兴趣了.处于以前在S3c2440上对linux的移植使用经验.心里猜测对于android设备应该也这样.所以通过搜索资料整理如 ...

  10. hdu1824(two-sat)

    传送门:Let's go home 题意:有n个队伍要回家,但是每队必须留下一人,而且m个限制,a留下,b必须回家,问能否在限制条件下每队留下一人. 分析:将每个队的队长和两个队员当成i和i':然后对 ...