分享
 
 
 

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

王朝java/jsp·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

数据结构――栈、队列和树

开发者可以使用数组与链表的变体来建立更为复杂的数据结构。本节探究三种这样的数据结构:栈、队列与树。当给出算法时,出于简练,直接用Java代码。

栈是这样一个数据结构,其数据项的插入和删除(获取)都只能在称为栈顶的一端完成。因为最后插入的数据项就是最先要删除的数据项,开发者往往将栈称为LILO(last-in, first-out)数据结构。

数据项压入(插入)或者弹出(删除或取得)栈顶。图13示例了一个有三个String数据项的栈,每个数据项压入栈顶。

图13 有三个以压入String数据项的栈

如图13所示,栈在内存中是向下建起来的。对于每个数据项的压入,之前栈顶的数据项以及其下面的所有数据项都得向下移,当要从栈中弹出一个数据项时,取得栈顶元素并将其从栈中删除。

栈在许多程序设计环境下非常有用。两个非常普通的环境:

·栈保存返回地址:当代码调用一个方法时,调用指令后的第一条指令的地址压入当前线程的方法调用栈的顶端。当执行被调用方法的返回指令时,该地址从栈顶弹出,然后从该地址处继续执行。假如一个方法调用了另一个方法,栈的LIFO行为模式确保了第二个方法的返回指令将执行转移到第一个方法,而第一个方法的返回指令能够将执行转移到调用第一个方法的代码的代码。结果就是,栈代表被调用方法“记住了”返回地址。

·栈保存每个被调用方法的参数和局部变量:当调用一个方法时,JVM在靠近返回地址处分配内存存储所有被调用方法的参数和局部变量。假如方法是个实例方法,存储在栈中的其中一个参数是当前对象的引用this。

一般可以使用一维数组或单链表实现一个栈。假如使用一维数组,一个常命名为top的整型变量保存栈顶数据项的索引。类似地,一个常命名为top的引用变量引用单链表情形下的栈顶节点(含有栈顶数据项)。

根据Java's Collections API中发现的体系结构建模栈的实现。这个实现由一个Stack接口,ArrayStack和LinkedListStack实现类以及FullStackException支持类组成。为了便于发布,将这些类打包在com.javajeff.cds包中,其中的cds表示复杂数据结构。清单8给出了Stack接口。

清单8. Stack.java

// Stack.java

package com.javajeff.cds;

public interface Stack

{

boolean isEmpty ();

Object peek ();

void push (Object o);

Object pop ();

}

Stack的四个方法分别是确定栈是否为空,获得栈顶数据项而没有删除,任意数据项入栈,获得并删除栈顶元素。除了一个具体于实现的构造方法之外,你的程序只需调用这些方法就足够了。

清单9 给出了Stack的基于一维数组的实现:

清单9 ArrayStack.java

// ArrayStack.java

package com.javajeff.cds;

public class ArrayStack implements Stack

{

private int top = -1;

private Object[] stack;

public ArrayStack(int maxElements)

{

stack = new Object[maxElements];

}

public boolean imEmpty()

{

return top == -1;

}

public Object peek()

{

if (top < 0)

throw new java.util.EmptyStackException();

return stack[top];

}

public void push(Object o)

{

if (top == stack.length - 1)

throw new FullStackException();

stack[++top] == 0;

}

public Object pop()

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有