#pragma warning (disable: 4786)
#include <iostream>
#include <stack>
#include <string>
using namespace std;
//要注意当前访问的页面就是backset栈顶的元素,切记
//理解浏览器前进后退的含义自己编
int main(){
stack<string> back,forward;
string command,url;
back.push("http://www.acm.org/");
while (cin>>command,command!="QUIT")
{
if (command == "VISIT")
{
cin>>url;
back.push(url);
cout<<url<<endl;
while(!forward.empty()) forward.pop();
}
else if (command == "BACK")
{
if (back.size()==1)//等于1表示就是当前的页面,已经不能够弹栈了
{
cout<<"Ignored"<<endl;
}
else
{
url = back.top();
forward.push(url);
back.pop();
url = back.top();
cout<<url<<endl;
}
}
else if (command == "FORWARD")
{
if (forward.size()==0)//forward的大小可以为零,这点要与backset区分开来
{
cout<<"Ignored"<<endl;
}
else
{
url= forward.top();
back.push(url);
forward.pop();
cout<<url<<endl;
}
}
}
return 0;
}