【栈-例题】网页跳转-C++

描述

蒜头君每天都在用一款名为 “蒜厂浏览器” 的软件。在这个浏览器中,一共三种操作:打开页面、回退和前进。它们的功能如下:

打开页面:在地址栏中输入网址,并跳转到网址对应的页面;

回退:返回到上一次访问的页面;

前进:返回到上次回退前的页面,如果上一次操作是打开页面,那么将无法前进。

现在,蒜头君打开浏览器,进行了一系列操作,你需要输出他每次操作后所在页面的网址。


输入
第一行输入一个整数 t(0 < t <= 10),表示有 t 组数据。

第二行输入一个整数 n(0 < n <= 100000), 表示蒜头君的操作次数。

接下来一共 n 行,每行首先输入一个字符串,如果是VISIT,后面接着输入一个不含有空格和换行的网址(网址长度小于 100),表示蒜头君在浏览器地址栏中输入的网址;如果是BACK,表示蒜头君点击了回退按钮;如果是FORWARD,表示蒜头君点击了前进按钮。


输出
对于每次操作,如果蒜头君能操作成功,输出蒜头君操作之后的网址,否则输出"Ignore"。假设蒜头君输入的所有网址都是合法的。


输入样例 1 

1
10
VISIT https://www.jisuanke.com/course/476
VISIT https://www.taobao.com/
BACK
BACK
FORWARD
FORWARD
BACK
VISIT https://www.jisuanke.com/course/429
FORWARD
BACK
输出样例 1

https://www.jisuanke.com/course/476
https://www.taobao.com/
https://www.jisuanke.com/course/476
Ignore
https://www.taobao.com/
Ignore
https://www.jisuanke.com/course/476
https://www.jisuanke.com/course/429
Ignore
https://www.jisuanke.com/course/476

来源

计蒜客

这题本质上其实是考察栈的使用,用两个栈可以维护,一个栈用来保存回退的网页信息,一个栈用来保存前进的网页信息。
相信这一点大家都可以看出来。然后我们先分析三个操作分别需要做些什么,画图理解一下;
VISIT网页1:
在这里插入图片描述
这个很简单,直接在now里面插入一个网页1就可以了。
BACK:
初步思路:

if(!now.empty())
{
      .....
}
else cout<<"Ignore"<<endl;

但是行吗? 很明显,当now里面只有一个网页1时,虽然now不空,但是我们是无法进行后退操作的!
于是我们将写法改成:

if(now.empty())
{
	cout<<"Ignore"<<endl;
	continue;
}
back.push(now.top());
now.pop();
if(!now.empty())
	cout<<now.top()<<endl;
else
{
	cout<<"Ignore"<<endl;
	now.push(back.top());
	back.pop();
	continue;
}

意思是:
首先,当now空时,一定无法完成back操作, 排除这种情况后,我们就可以取出它的top,放入back中,然后进行pop操作,如果此时now还不为空,那么就可以输出这个now.top(),否则再把之前取出的top给放回去,back给pop掉即可。


接下来是FORWARD操作;
这个操作依然有点麻烦,但是只要理解好了上面的BACK操作就容易写了。

if(!back.empty())
{
	cout<<back.top()<<endl;
	now.push(back.top());
	back.pop();
}
else
{
	cout<<"Ignore"<<endl;
}

还是比较容易理解的。如果back不空,直接输出back.top,然后打入now中,然后pop掉就可以了。因为没有now中那样的限制,所以代码看起来要简单很多。


但是我们发现,这样写了三个操作,依然无法通过这道题。

哪里出了问题?

我们往回退,BACK和FORWARD已经很完整的,问题只可能出在VISIT上。
我们在VISIT的时候是不是还忽略了什么重要的操作?
画图看看:
假如本来是这样:
在这里插入图片描述
当我们再插入一个网页4,变成了这样
在这里插入图片描述
但是这时,我如果想要进行FORWARD操作,我们可以进到网页3吗?

显然不行!

所以我们遗漏掉的重要操作是:

在VISIT一个网址的时候清空栈back!

所以VISIT板块的代码如下:

while(!back.empty())
{
	back.pop();
}
cin>>web;
now.push(web);
cout<<web<<endl;

这就是这道题目的完整题解,下面是完整代码,感谢支持。

#include<bits/stdc++.h>
using namespace std;
stack<string> now;
stack<string> back;
int main()
{
    string ins,web;
    int t;
    cin>>t;
    for(int i=1;i<=t;i++)
    {
        int n;
        cin>>n;
        for(int i=1;i<=n;i++)
        {
            cin>>ins;
            if(ins=="VISIT")
            {
            	while(!back.empty())
				{
					back.pop();
				}
                cin>>web;
                now.push(web);
                cout<<web<<endl;
            }
            if(ins=="BACK")
            {
            	if(now.empty())
            	{
            		cout<<"Ignore"<<endl;
            		continue;
				}
				back.push(now.top());
				now.pop();
                if(!now.empty())cout<<now.top()<<endl;
                else
                {
                	cout<<"Ignore"<<endl;
					now.push(back.top());
					back.pop();
					continue;
				}
            }
            if(ins=="FORWARD")
            {
            	if(!back.empty())
            	{
					cout<<back.top()<<endl;
					now.push(back.top());
					back.pop();
				}
				else
				{
					cout<<"Ignore"<<endl;
				}
			}
        }
        while(!back.empty())
		{
			back.pop();
		}
        while(!now.empty())
		{
			now.pop();
		}
    }
    return 0;
}

ov.

个人博客地址: www.moyujiang.com 或 moyujiang.top
原文地址:https://www.cnblogs.com/moyujiang/p/11167769.html