POJ 1028:Web Navigation

原创 2015年07月11日 10:05:08

Web Navigation
Time Limit: 1000MS   Memory Limit: 10000K
Total Submissions: 30828   Accepted: 13821

Description

Standard web browsers contain features to move backward and forward among the pages recently visited. One way to implement these features is to use two stacks to keep track of the pages that can be reached by moving backward and forward. In this problem, you are asked to implement this. 
The following commands need to be supported: 
BACK: Push the current page on the top of the forward stack. Pop the page from the top of the backward stack, making it the new current page. If the backward stack is empty, the command is ignored. 
FORWARD: Push the current page on the top of the backward stack. Pop the page from the top of the forward stack, making it the new current page. If the forward stack is empty, the command is ignored. 
VISIT : Push the current page on the top of the backward stack, and make the URL specified the new current page. The forward stack is emptied. 
QUIT: Quit the browser. 
Assume that the browser initially loads the web page at the URL http://www.acm.org/

Input

Input is a sequence of commands. The command keywords BACK, FORWARD, VISIT, and QUIT are all in uppercase. URLs have no whitespace and have at most 70 characters. You may assume that no problem instance requires more than 100 elements in each stack at any time. The end of input is indicated by the QUIT command.

Output

For each command other than QUIT, print the URL of the current page after the command is executed if the command is not ignored. Otherwise, print "Ignored". The output for each command should be printed on its own line. No output is produced for the QUIT command.

Sample Input

VISIT http://acm.ashland.edu/
VISIT http://acm.baylor.edu/acmicpc/
BACK
BACK
BACK
FORWARD
VISIT http://www.ibm.com/
BACK
BACK
FORWARD
FORWARD
FORWARD
QUIT

Sample Output

http://acm.ashland.edu/
http://acm.baylor.edu/acmicpc/
http://acm.ashland.edu/
http://www.acm.org/
Ignored
http://acm.ashland.edu/
http://www.ibm.com/
http://acm.ashland.edu/
http://www.acm.org/
http://acm.ashland.edu/
http://www.ibm.com/
Ignored

水题,题意就是模拟访问网页,看当前网页到了哪里。

代码:

#include <iostream>
#include <vector>
#include <map>
#include <algorithm>
#include <cmath>
#include <string>
#include <cstring>
using namespace std;

map <int,string> web;

int main()
{	
	//freopen("input.txt","r",stdin);
	//freopen("out.txt","w",stdout);

	string operate;
	string website;

	int cur=1,zong=1;
	web[1]="http://www.acm.org/";

	while(cin>>operate)
	{
		if(operate=="QUIT")
			break;
		if(operate=="VISIT")
		{
			cin>>website;
			web[++cur]=website;
			zong=cur;
			cout<<website<<endl;
		}
		if(operate=="BACK")
		{
			if(cur==1)
			{
				cout<<"Ignored"<<endl;
			}
			else
			{
				cur--;
				cout<<web[cur]<<endl;
			}
		}
		if(operate=="FORWARD")
		{
			if(cur==zong)
			{
				cout<<"Ignored"<<endl;
			}
			else
			{
				cur++;
				cout<<web[cur]<<endl;
			}
		}
	}

	//system("pause");
	return 0;
}



版权声明:本文为博主原创文章,未经博主允许不得转载。

Web Navigation

Description Standard web browsers contain features to move backward and forward among the pages rec...
  • wsnbb123456789
  • wsnbb123456789
  • 2015年11月03日 15:44
  • 515

<poj1028> Web Navigation

Web Navigation Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 23618  ...
  • cs_zlg
  • cs_zlg
  • 2012年07月14日 10:32
  • 1493

Web Navigation

FJNU.1060PKU.1028DescriptionStandard web browsers contain features to move backward and forward amon...
  • yahreso
  • yahreso
  • 2008年02月15日 19:57
  • 360

POJ1028 Web Navigation【堆栈+模拟】

Web Navigation Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 34314   Accepted: ...
  • tigerisland45
  • tigerisland45
  • 2017年06月14日 08:06
  • 282

POJ - 1028 Web Navigation

栈的应用
  • sinat_29278271
  • sinat_29278271
  • 2016年02月24日 20:15
  • 154

poj 1028 Web Navigation

Description Standard web browsers contain features to move backward and forward among the pages r...
  • u014119694
  • u014119694
  • 2014年09月14日 19:01
  • 210

poj 1028 Web Navigation

题目: Standard web browsers contain features to move backward and forward among the pages recently vi...
  • u010064842
  • u010064842
  • 2013年04月05日 14:25
  • 1307

POJ 1028 - Web Navigation

STL练习题. 题意挺好理解, 不说了.
  • u014247806
  • u014247806
  • 2014年05月02日 18:35
  • 897

POJ 1028——Web Navigation

一道模拟题。当用cin读入字符串的时候会被空格打断。 代码如下: #include #include using namespace std; stack backward; stack for...
  • u010734277
  • u010734277
  • 2014年03月15日 11:08
  • 343

POJ 1028 Web Navigation

昨晚迎来了ACM实验室的面试。匆匆从中心赶到大软园,又匆匆的赶回来……FU神和植神面的,没问什么技术上的问题,更多是考虑我假设进入实验室要面临的各种麻烦问题,比如两个校区来回赶、影响这边课业等等。 回...
  • u012538759
  • u012538759
  • 2013年12月08日 09:19
  • 530
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:POJ 1028:Web Navigation
举报原因:
原因补充:

(最多只允许输入30个字)