我正在尝试使用我的链接列表来实现堆栈,即DSAStack.java
,即DSALinkedList.java
我该怎么办?我想我应该push()
执行insertFirst()
而pop()
执行peekFirst()
和removeFirst()
来获取LIFO行为?那isEmpty()
怎么样
和其他方法?
我不确定,请帮帮我。使用代码的清晰解释将非常明显。提前谢谢!
以下是DSAStack.java
public class DSAStack implements Iterable {
public static int DEFAULT_CAPACITY = 100;
private DSALinkedList list;
private int count;
private Object[] stack;
public DSAStack() {
count = 0;
stack = new Object[DEFAULT_CAPACITY];
}
public DSAStack(int maxCapacity) {
count = 0;
stack = new Object[maxCapacity];
}
public int getCount() {
return count;
}
public boolean isEmpty() {
boolean empty = (count == 0);
return empty;
}
public boolean isFull() {
boolean full = (count == stack.length);
return full;
}
public void push(Object value) {
if (isFull())
throw new IllegalArgumentException("Stack is full");
else
stack[count] = value;
count++;
}
public Object pop() {
Object topVal = top();
count--;
return topVal;
}
public Object top() {
Object topVal;
if (isEmpty())
throw new IllegalArgumentException("Stack is empty");
else
topVal = stack[count-1];
return topVal;
}
public Iterator iterator() {
return list.iterator();
}
}
这是DSALinkedList.java
import java.util.*;
public class DSALinkedList {
public DSAListNode head;
public DSAListNode tail;
Object[] newValue;
public DSALinkedList() {
head = null;
tail = null;
}
public void insertFirst(Object newValue){
DSAListNode newNd;
newNd = new DSAListNode(newValue);
if (head == null) {
head = newNd;
tail = newNd;
} else {
newNd.setNext(head);
head = newNd;
}
}
public void insertLast(Object newValue){
DSAListNode newNd;
newNd = new DSAListNode(newValue);
if(head == null){
head = newNd;
} else {
tail.next = newNd;
tail = newNd;
}
}
public boolean isEmpty() {
return (head == null);
}
public Object peekFirst(){
Object nodeValue;
if (head == null)
throw new IllegalArgumentException("head is empty");
else
nodeValue = head.getValue();
return nodeValue;
}
public Object peekLast(){
Object nodeValue;
if (head == null)
throw new IllegalArgumentException("head is empty");
else
nodeValue = tail.getValue();
return nodeValue;
}
public Object removeFirst(){
Object nodeValue;
if (head == null){
throw new IllegalArgumentException("head is empty");
} else {
nodeValue = head.getValue();
head = head.getNext();
}
return nodeValue;
}
}
答案 0 :(得分:1)
您的DSAStack类是用户和链接列表之间的接口。因此,该类提供LIFO接口并强制它在用户上。从这里开始,它应该隐藏链表中的实现,这样用户就不必担心插入最后或插入第一个,他们只想插入。
所以回答你的问题。 DSAStack需要执行以下操作:
- size() -> returns int size - push(Object e) -> returns bool (able to be inserted) - pop() -> returns Object and removes it from linkedlist - peek() -> returns Object - isEmpty() -> returns bool if empty
您的DSAStack并不意味着保存任何数据。所以你不需要计数或堆栈变量。相反,我们需要将它们存储在DSALinkedList类中。因此,DSAStack应该实例化一个DSALinkedList对象,传递maxCapacity,然后启动该对象。
当用户说他们想在DSAStack上使用pop()时,该类需要告诉DSALinkedList,嘿!我想弹出你的一个物体!现在DSALinkedList需要在这里实现细节。
重写代码就像这样:
public DSAStack(int maxCapacity) {
list = new DSALinkedList[maxCapacity];
}
public int getCount() {
return list.size();
}
public boolean isEmpty() {
return list.isEmpty();
}
public boolean isFull() {
return list.isFull();
}
public void push(Object value) {
list.insertLast(value);
}
public Object pop() {
return list.removeLast();
}
public Object top() {
return list.peekLast();
}
public Iterator iterator() {
return list.iterator();
}
}