关于java中stack和Queue的问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于java中stack和Queue的问题相关的知识,希望对你有一定的参考价值。

想问下,在stack中,不调用任何如vector之类的已有语言的情况下,如何写以下两个类
1.add(Integer n),增加一个int到已有的stack中(已经在另外一个class中定义好了stack了)
2.返回stack中最小值并且把这个值从stack中移除

还有想问下,如果是Queue的情况下如何做到这两点?不过第二点返回的是一个Object,并且是queue中最长的一个并删除掉
万分感谢

很简单,在类中建立一个数组,然后根据各个方法的要求对数组中的数据进行操作。 参考技术A java中不是有Stack和Queue了,干嘛自己写?多此一举 参考技术B 解压......\jdk1.6.0\src.zip然后看源码~~

java集合框架:浅谈如何使用LInkedList实现队列(Queue)和堆栈(Stack)

Java中的LinkedList?是采用双向循环列表实现的。
利用LinkedList?可以实现栈(stack)、队列(queue)

下面写两个例子
学生类:
int stuId;

public int getStuId() {
    return stuId;
}
public void setStuId(int stuId) {
    this.stuId = stuId;
}
public String getStuName() {
    return stuName;
}
public void setStuName(String stuName) {
    this.stuName = stuName;
}
public int getAge() {
    return age;
}
public void setAge(int age) {
    this.age = age;
}
String stuName;

int age;

public Student(){

}
public Student(int stuId,String stuName,int age){
    this.age = age;
    this.stuId = stuId;
    this.stuName = stuName;
}
public String toString() {

return ("学生姓名:"+this.stuName+"学生年龄"+this.age+"学生编号"+this.stuId);

}

队列
自定义方法实现LInkedList
LinkedList lists =new LinkedList();

public  void push(Object object){
    lists.addLast(object);
}
public Object pop(){
    return lists.removeFirst();
}

实现方法
System.out.println("在队列中添加对象");
MyQuene quene = new MyQuene();
quene.push(new Student(1,"学生1",20));
quene.push(new Student(2,"学生2",21));
quene.push(new Student(3,"学生3",23));
for (Object object : quene.lists) {
Student student = (Student)object;
System.out.println(student.toString());
}
System.out.println("在队列中删除对象");
quene.pop();
for (Object object : quene.lists) {
Student student = (Student)object;
System.out.println(student.toString());
}

堆栈:

自定义方法,并实现

LinkedList lists =new LinkedList();

public void push(Object object){
    lists.addFirst(object);
}

public Object pop(){
    return lists.removeLast();
}

System.out.println("在队列中添加对象");
MyStack Stack = new MyStack();
Stack.push(new Student(1,"学生1",20));
Stack.push(new Student(2,"学生2",21));
Stack.push(new Student(3,"学生3",23));
for (Object object : Stack.lists) {
Student student = (Student)object;
System.out.println(student.toString());
}
System.out.println("在队列中删除对象");
Stack.pop();
for (Object object : Stack.lists) {
Student student = (Student)object;
System.out.println(student.toString());
}

以上是关于关于java中stack和Queue的问题的主要内容,如果未能解决你的问题,请参考以下文章

6-5-1:STL之stack和queue——stack和queue的快速入门常用接口以及适配器的概念

数据结构与算法队列

解决关于stack溢出的问题

关于JAVA队列的申明

9-java安全——关于构造CC2链的几个问题

9-java安全——关于构造CC2链的几个问题