• 【栈-例题】网页跳转-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
  • 相关阅读:
    Pikachu漏洞平台---XSS(Cross-Site Scripting) 跨站脚本
    Pikachu漏洞练习平台(暴力破解模块)
    DVWA-- 不安全得验证码Insecure CAPTCHA
    DVWA-文件上传 File Upload
    DVWA之CSRF(跨站请求伪造)
    绑定方法与非绑定方法
    XML,面向对象基础
    configparser ,subprocess , xlrd ,xlwt 模块
    logging ,re 模块
    random,json,pickle,hashlib,shutil,hmac,shelve 模块
  • 原文地址:https://www.cnblogs.com/moyujiang/p/11167769.html
Copyright © 2020-2023  润新知