1. 描述
  2. 蒜头君每天都在用一款名为 “蒜厂浏览器” 的软件。在这个浏览器中,一共三种操作:打开页面、回退和前进。它们的功能如下:
  3. 打开页面:在地址栏中输入网址,并跳转到网址对应的页面;
  4. 回退:返回到上一次访问的页面;
  5. 前进:返回到上次回退前的页面,如果上一次操作是打开页面,那么将无法前进。
  6. 现在,蒜头君打开浏览器,进行了一系列操作,你需要输出他每次操作后所在页面的网址。
  7. 输入
  8. 第一行输入一个整数 t(0 < t <= 10),表示有 t 组数据。
  9. 第二行输入一个整数 n(0 < n <= 100000), 表示蒜头君的操作次数。
  10. 接下来一共 n 行,每行首先输入一个字符串,如果是VISIT,后面接着输入一个不含有空格和换行的网址(网址长度小于 100),表示蒜头君在浏览器地址栏中输入的网址;如果是BACK,表示蒜头君点击了回退按钮;如果是FORWARD,表示蒜头君点击了前进按钮。
  11. 输出
  12. 对于每次操作,如果蒜头君能操作成功,输出蒜头君操作之后的网址,否则输出"Ignore"。假设蒜头君输入的所有网址都是合法的。
  13. 输入样例 1
  14. 1
  15. 10
  16. VISIT https://www.jisuanke.com/course/476
  17. VISIT https://www.taobao.com/
  18. BACK
  19. BACK
  20. FORWARD
  21. FORWARD
  22. BACK
  23. VISIT https://www.jisuanke.com/course/429
  24. FORWARD
  25. BACK
  26. 输出样例 1
  27. https://www.jisuanke.com/course/476
  28. https://www.taobao.com/
  29. https://www.jisuanke.com/course/476
  30. Ignore
  31. https://www.taobao.com/
  32. Ignore
  33. https://www.jisuanke.com/course/476
  34. https://www.jisuanke.com/course/429
  35. Ignore
  36. https://www.jisuanke.com/course/476
  37. 来源
  38. 计蒜客

这题本质上其实是考察栈的使用,用两个栈可以维护,一个栈用来保存回退的网页信息,一个栈用来保存前进的网页信息。

相信这一点大家都可以看出来。然后我们先分析三个操作分别需要做些什么,画图理解一下;

VISIT网页1:



这个很简单,直接在now里面插入一个网页1就可以了。

BACK:

初步思路:

  1. if(!now.empty())
  2. {
  3. .....
  4. }
  5. else cout<<"Ignore"<<endl;

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

于是我们将写法改成:

  1. if(now.empty())
  2. {
  3. cout<<"Ignore"<<endl;
  4. continue;
  5. }
  6. back.push(now.top());
  7. now.pop();
  8. if(!now.empty())
  9. cout<<now.top()<<endl;
  10. else
  11. {
  12. cout<<"Ignore"<<endl;
  13. now.push(back.top());
  14. back.pop();
  15. continue;
  16. }

意思是:

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


接下来是FORWARD操作;

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

  1. if(!back.empty())
  2. {
  3. cout<<back.top()<<endl;
  4. now.push(back.top());
  5. back.pop();
  6. }
  7. else
  8. {
  9. cout<<"Ignore"<<endl;
  10. }

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


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

哪里出了问题?

我们往回退,BACK和FORWARD已经很完整的,问题只可能出在VISIT上。

我们在VISIT的时候是不是还忽略了什么重要的操作?

画图看看:

假如本来是这样:



当我们再插入一个网页4,变成了这样



但是这时,我如果想要进行FORWARD操作,我们可以进到网页3吗?

显然不行!

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

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

所以VISIT板块的代码如下:

  1. while(!back.empty())
  2. {
  3. back.pop();
  4. }
  5. cin>>web;
  6. now.push(web);
  7. cout<<web<<endl;

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

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. stack<string> now;
  4. stack<string> back;
  5. int main()
  6. {
  7. string ins,web;
  8. int t;
  9. cin>>t;
  10. for(int i=1;i<=t;i++)
  11. {
  12. int n;
  13. cin>>n;
  14. for(int i=1;i<=n;i++)
  15. {
  16. cin>>ins;
  17. if(ins=="VISIT")
  18. {
  19. while(!back.empty())
  20. {
  21. back.pop();
  22. }
  23. cin>>web;
  24. now.push(web);
  25. cout<<web<<endl;
  26. }
  27. if(ins=="BACK")
  28. {
  29. if(now.empty())
  30. {
  31. cout<<"Ignore"<<endl;
  32. continue;
  33. }
  34. back.push(now.top());
  35. now.pop();
  36. if(!now.empty())cout<<now.top()<<endl;
  37. else
  38. {
  39. cout<<"Ignore"<<endl;
  40. now.push(back.top());
  41. back.pop();
  42. continue;
  43. }
  44. }
  45. if(ins=="FORWARD")
  46. {
  47. if(!back.empty())
  48. {
  49. cout<<back.top()<<endl;
  50. now.push(back.top());
  51. back.pop();
  52. }
  53. else
  54. {
  55. cout<<"Ignore"<<endl;
  56. }
  57. }
  58. }
  59. while(!back.empty())
  60. {
  61. back.pop();
  62. }
  63. while(!now.empty())
  64. {
  65. now.pop();
  66. }
  67. }
  68. return 0;
  69. }

ov.

【栈-例题】网页跳转-C++的更多相关文章

  1. 使用IE11抓包,防止在网页跳转时抓包数据被清除的方法

    引:最近在研究使用python实现模拟登陆各大网站,在使用IE11进行抓包分析网站登陆的逻辑结构的时候,发现每次在抓包的时候,当网页跳转的时候,抓包数据会被清除,让我很是郁闷,最终在查阅相关资料以及自 ...

  2. 总结PHP中几种常用的网页跳转代码

    网页跳转的意思就是指当你在浏览器中访问A页面时,会自动跳转到B页面,往往网页跳转用在404页面中会比较多点.至于怎么实现网页跳转,网上已经提供了很多的方法,有些方法是不可行的,经过测试,叶德华今天就在 ...

  3. IIS 7.5 使用URL Rewrite模块简单设置网页跳转

    原文 IIS 7.5 使用URL Rewrite模块简单设置网页跳转 我们都知道Apache可以在配置文件里方便的设置针对网页或网站的rewrite,但是最近接手了一组IIS服务器,发现这货简单的没有 ...

  4. 小结php中几种网页跳转

    1.使用网页中<a href=.....></a>实现跳转: 2.<form action="php_request2.php" method=&qu ...

  5. 微信跳转,wap网页跳转微信打开指定页面

    最近一朋友的客户有这么一需求,wap网页跳转微信打开指定页面,让用户去关注公众号.想这么干,通过网页跳转到微信并打开带有二维码的网页,用户长按识别二维码就可以关注了.想法很好,于是去搜索了“微信跳转, ...

  6. asp.net(c#)网页跳转 方法小结

    返回 打印 asp.net(c#)网页跳转七种方法小结_实用技巧_脚本之家 在asp.net下,经常需要页面的跳转,下面是具体的几种方法.跳转页面是大部编辑语言中都会有的,正面我们来分别介绍一下关于. ...

  7. BOM模型中常用对象 定义计数器 网页跳转 网页前进后退

    今天上午学了的BOM模型中常用对象,了解了一部分的属性 For循环的规律 外层循环控制行 内层循环控制列 <!doctype html> <html> <head> ...

  8. 【Django】网页跳转的问题

    这两天有个比较奇怪了问题困扰着我,就是网页跳转之后页面没有变化,虽然url已经变了,但是页面还是原来的,只是表单数据清空了 就是http://127.0.0.1:8000/signup_signin/ ...

  9. php程序开发之实现网页跳转

    php程序开发之实现网页跳转的三种方式 2017年04月16日 20:44:14 阅读数:3352 PHP目前是用来开发WEB项目的首选语言.Web项目中,从一个网页跳转到另一个网页是最常用的技术之一 ...

  10. 微信网页跳转页面常见bug处理

    微信网页跳转页面常见bug处理 1.不要直接用a链接直接跳转 2.url后加上时间戳 function gohome() { window.location.href = "../home/ ...

随机推荐

  1. .NET Core整合log4net以及全局异常捕获实现2

    Startup代码 public static ILoggerRepository repository { get; set; } public Startup(IConfiguration con ...

  2. 毕设(一)C#的百度api调用

    这个学期就要毕业了,选了一个无人机地面站软件设计的题目,这几天也开始着手做, 首先做了一个百度地图的调用,这里因为是上位机的开发,所有就不介绍Javascript的 调用方法,核心是用到一个类Http ...

  3. PyCharm安装MicroPython插件

    转载请注明文章来源,更多教程可自助参考docs.tpyboard.com,QQ技术交流群:157816561,公众号:MicroPython玩家汇 前言 PyCharm可以说是当今最流行的一款Pyth ...

  4. python机器学习系列之环境搭建

    Windows系统下python2.7,numpy,matplotlib安装 1.  python2.7从https://www.python.org/downloads/release/python ...

  5. java集合框架collection(2)ArrayList和LinkedList

    ArrayList是基于动态数组实现的list,而LinkedList是基于链表实现的list.所以,ArrayList拥有着数组的特性,LinkedList拥有着链表的特性. 优缺点 ArrayLi ...

  6. Jmeter 如何把数据库的数据依次获取作为参数传入下一个请求?附栗子

    某一天碰到一个问题,觉得很有必要整理一篇文章出来~ 因为项目的原因,假设我们要实现如下要求: 从数据库的用户表里获取用户信息,并作为参数全部传递给登录请求,分别完成登录操作. 一.jmeter连接数据 ...

  7. Linux 中文设置

    命令  locale,查看Linux默认系统语言 [root@VM_0_15_centos /]# locale LANG=en_US.utf8 LC_CTYPE="en_US.utf8&q ...

  8. 原子操作CAS-最小的线程安全

    原文连接:(http://www.studyshare.cn/blog-front/blog/details/1166/0 )一.原子操作是什么? 如果有两个线程分别执行两个操作A和B,从第一个线程执 ...

  9. python基础(1)--input print if else elif while 用法说明

    1 变量名的命名规则: 由数字,字母和下划线组成,但是不能以数字开头命名变量.例如 a ,b ,c ,name ,user1 user_id 等都可作为变量名称. 1a,2b 3cd等都不行.特别注意 ...

  10. php中使用trait设计单例

    trait Singleton { private static $instace = null; private function __construct() { } private functio ...