1.4.28一个队列实现的栈。使用一个队列实现一个栈,使得每个栈操作所需的队列操作数量为线性级别。提示:要删除一个元素,将队列中的所有元素一一出列,除了最后一个元素,应该将它删除并返回(这种方法的确非常低效)。
答:
public class E1d4d28<Item>
{
Queue<Item> q=new Queue<Item>();
public boolean isEmpty()
{
return q.isEmpty();
}
public int size()
{
return q.size();
}
public void push(Item item)
{
q.enqueue(item);
}
public Item pop()
{
int N=q.size();
while(N>1)
{
q.enqueue(q.dequeue());
N--;
}
Item item=q.dequeue();
return item;
}
public static void main(String[] args)
{
E1d4d28<String> s=new E1d4d28<String>();
while(!StdIn.isEmpty())
{
String item=StdIn.readString();
s.push(item);
}
StdOut.printf("Stack is Empty:%s ",s.isEmpty());
StdOut.printf("Stack size is:%s ",s.size());
StdOut.printf("Stack top element is:%s ",s.pop());
StdOut.printf("Stack top element is:%s",s.pop());
}
}
答:
public class E1d4d28<Item>
{
Queue<Item> q=new Queue<Item>();
public boolean isEmpty()
{
return q.isEmpty();
}
public int size()
{
return q.size();
}
public void push(Item item)
{
q.enqueue(item);
}
public Item pop()
{
int N=q.size();
while(N>1)
{
q.enqueue(q.dequeue());
N--;
}
Item item=q.dequeue();
return item;
}
public static void main(String[] args)
{
E1d4d28<String> s=new E1d4d28<String>();
while(!StdIn.isEmpty())
{
String item=StdIn.readString();
s.push(item);
}
StdOut.printf("Stack is Empty:%s ",s.isEmpty());
StdOut.printf("Stack size is:%s ",s.size());
StdOut.printf("Stack top element is:%s ",s.pop());
StdOut.printf("Stack top element is:%s",s.pop());
}
}