补番计划

Time Limit : 4000/2000ms (Java/Other)   Memory Limit : 65535/32768K (Java/Other)
Total Submission(s) : 8   Accepted Submission(s) : 1

Font: Times New Roman | Verdana | Georgia

Font Size: ← →

Problem Description

阿聪是一个日漫狂魔。暑假在家的时候,他有12小时在补番。12小时在睡觉。

可是动漫的质量有好有坏,选择看哪一部动漫一直都是一个问题。

于是。他做了一个补番的队列。每一次当他完结某部动漫后,他会选择队列最前面的那部动漫观看,并从队首删除。

阿聪想补的番通常有2个途径。一个是来自网上网友的推荐,他会把网友推荐的动漫放在队列的末尾。

还有一种是来自现实朋友的推荐,他会把朋友推荐的动漫直接放在队列最前面。

阿聪有时候也会在贴吧里听到有人说某部动漫一点也不好看,或者是无意中被透剧了,这个时候阿聪就会非常生气的把这部动漫从队列中删除。

Input

第一行有一个整数T(T<=5),表示測试组数

接下来有T组数据

每一组数据第一行有一个数字Q(Q<=10000)。表示这组数据中的操作数。

接下来Q行中,分别有以下几种格式

0

1 [动漫名字]

2 [动漫名字]

3 [动漫名字]

Output

0表示阿聪如今要补番了,假设队列为空,则输出-1。否则取出队列的队首的动漫名字,并将它从队首中删除,假设这部动漫阿聪已经看过了, 则相同输出-1。否则输出动漫名字并换行,并标记为看过了

1表示网友推荐阿聪了一部动漫。阿聪把这部动漫增加到了队列末尾

2表示朋友推荐阿聪了一部动漫。阿聪把这部动漫增加到了队列首端

3表示阿聪不想看这部动漫了,他会从队列中删除全部这部动漫的(仅仅会删除在这个操作之前已存在队列中的,并不会影响后面的操作)

注意动漫名字都是用[]括起来的。名字中仅仅含有下划线数字字母并区分大写和小写,且2<=动漫名字长度<=50

Sample Input

2
7
0
1 [Sword_Art_Online]
1 [Your_Lie_in_April]
2 [sakura_sou_no_pet_na_kanojo]
0
0
0
6
1 [Your_Lie_in_April]
1 [Your_Lie_in_April]
2 [Is_the_order_a_rabbit]
3 [Is_the_order_a_rabbit]
0
0

Sample Output

-1
sakura_sou_no_pet_na_kanojo
Sword_Art_Online
Your_Lie_in_April
Your_Lie_in_April
-1

尽管没学过c++  。

感觉应该和java差点儿相同。。。

题意中由于要从队尾  队首增加 所以选用---------------------双端队列

为了推断是否看过某番 。为了番名的唯一性----------------set容器

剩下的就是模拟了

#include <iostream>
#include <string.h>
#include <stdio.h>
#include <queue>
#include <set>
using namespace std;
int main()
{
set<string>s;
deque<string>q;
int ncase,n;
scanf("%d",&ncase);
while(ncase--)
{
s.clear();
while(!q.empty())
q.pop_back();
cin>>n;
for(int i=0;i<n;i++)
{
int x;
cin>>x;
if(x==0)
{
if(!q.empty())
{
string x1=q.front();q.pop_front();
if(s.find(x1)==s.end())
{
cout<<x1<<endl;
s.insert(x1);
}
else
{
cout<<-1<<endl;
} }
else
{
cout<<-1<<endl;
}
}
if(x==1)
{
string x2;
cin>>x2;
q.push_back(x2.substr(1,x2.length()-2));
}
if(x==2)
{
string x2;
cin>>x2;
q.push_front(x2.substr(1,x2.length()-2));
}
if(x==3)
{
string x2;
cin>>x2;
x2=x2.substr(1,x2.length()-2);
int count=q.size();
while(count--)
{
string x3=q.front();q.pop_front();
if(x3.compare(x2)!=0)
{
q.push_back(x3);
}
}
}
} }
return 0;
}

补番计划 (长沙理工大学第十一届程序设计竞赛)(双端队列+set容器+string)的更多相关文章

  1. 2014江西理工大学C语言程序设计竞赛高级组题解

    1001 Beautiful Palindrome Number 枚举回文数字前半部分,然后判断该数字是否满足,复杂度为O(sqrt(n))! 1002 Recovery Sequence  本题的核 ...

  2. 2016年江西理工大学C语言程序设计竞赛(高级组)

    问题 A: jxust 解法:争议的问题(是输入整行还是输入字符串),这里倾向输入字符串,然后判断是否含有jxust就行 #include<bits/stdc++.h> using nam ...

  3. 2016年江西理工大学C语言程序设计竞赛(初级组)

    问题 A: 木棒根数 解法:把所有的情况保存下来,加一下就好 #include<bits/stdc++.h> using namespace std; map<char,int> ...

  4. 2015年江西理工大学C语言程序设计竞赛(高级组)

    A 解法:DP+二分 dp[i]=max(dp[i],dp[j]+p[i].v)(i>j) dp[i]表示建立i点之后能够获得的最大值 int n,M; struct node { int l, ...

  5. 2013年江西理工大学C语言程序设计竞赛(高级组)

    A 解法:dfs搜索,注意一个剪枝,否则会超时(听说原本是个dp)? #include<stdio.h> //#include<bits/stdc++.h> #include& ...

  6. 2015年江西理工大学C语言程序设计竞赛(初级组)

    JankTao相亲记 解法:排序 #include<stdio.h> #include<string.h> #include<iostream> #include& ...

  7. 2013年江西理工大学C语言程序设计竞赛(初级组)

    ACM ICPC WORLD FINAL 解法:排序大家都知道,去重的话,初学者用数组就好了 #include<algorithm> #include<iostream> us ...

  8. 2018年江西理工大学C语言程序设计竞赛(初级组)一

     C语言竞赛初级组第一.二场答案:https://www.cnblogs.com/xingkongyihao/p/10046918.html  A: 逆序对 时间限制: 1 s      内存限制:  ...

  9. 2017年江西理工大学C语言程序设计竞赛(高级组)

    问题 A: 求近似值 #include <stdio.h> #include <time.h> #include <stdlib.h> using namespac ...

随机推荐

  1. 无法解析的DNS服务地址

    如果DNS服务器地址设置不当,可能会导致网速慢.出现弹窗广告.网址打不开.打开不是自己想要的网站等一系列问题. 请参考: DNS的作用是什么,怎样设置DNS? https://jingyan.baid ...

  2. [ Centos 7 iscsi搭建 及 1台客户端同时挂载多台iscsi服务端问题 ]

    一.什么是iscsi iSCSI技术是一种由IBM公司研究开发的,是一个供硬件设备使用的可以在IP协议的上层运行的SCSI指令集,这种指令集合可以实现在IP网络上运行SCSI协议,使其能够在诸如高速千 ...

  3. 移动开发之css3实现背景渐变效果

    前段时间由于手机项目需要实现一个背景渐变功能,  开始是想切个小背景图平铺下,  后来想到css3可以实现,如是用下面的代码就实现了. .sec_case_list li  span{ backgro ...

  4. Swagger 2.0 摘要

    官网地址:http://springfox.github.io/springfox/docs/current/

  5. TS 数据流分析学习

    TS 流.包结构以及同步 1. TS 流: 可以将TS流理解为一种单一码流.混合码流. 单一码流:TS流的基本组成单位是长度为188字节的TS包. 混合码流:TS流有多种数据组成,一个TS包中的数据可 ...

  6. Android:Activity统一堆栈管理(实现随时finish特定或是所有Activty)

    直接上代码: Activity管理类:AppManager /** * 应用程序Activity管理类:用于Activity管理和应用程序退出 * * @author BiHaidong * @ver ...

  7. CSU 1330 字符识别? 【找规律】

    你的任务是写一个程序进行字符识别.别担心,你只需要识别1, 2, 3,如下: .*.  ***  *** .*.  ..*  ..* .*.  ***  *** .*.  *..  ..* .*.  ...

  8. ASP.NET Core 2.2 基础知识(三) 静态文件

    什么是静态文件? HTML,CSS,JS,图片等都叫做静态文件. 要想提供静态文件给客户端,需要注册静态文件中间件. 我们先分别添加一个 WebAPI 项目,一个 Razor 视图项目,比较两个项目的 ...

  9. Android技巧:查看当前界面对应的活动

    常常接手别人的android代码,非常头疼不知道界面所对应的活动是哪一个.下面所说的方法可以完美解决. 新建一个BaseActivity类,继承自AppCompatActivity,并重写onCrea ...

  10. 【kruscal】【最小生成树】【搜索】bzoj1016 [JSOI2008]最小生成树计数

    不用Matrix-tree定理什么的,一边kruscal一边 对权值相同的边 暴搜即可.将所有方案乘起来. #include<cstdio> #include<algorithm&g ...