ADALIST - Ada and List

这道题时限6.5s,激动人心啊,好多人STL一顿乱写AC,哈哈,如果熟悉双端队列的话这道题其实是很水的。

题意:n个数的数列,然后接下来Q次操作,每次可以将某个数x插入第k个位置,那后面的数往后移。也可以删除第k个位置上的数,还可以是查询第k个位置上的数。

这就是双端队列的裸模板啊。下面简单介绍一下双端队列。

deque双端队列容器

deque与vector一样,采用线性表顺序存储结构,但deque采用分块的线性存储结构来存储数据,每个deque块用map块管理。deque块在头部和尾部都可以插入和删除元素而不需要移动其他元素。使用deque需要声明头文件包含“#include<deque>”。

1.创建deque对象:

①:创建没有任何元素的deque对象:deque<int/double>d。

②:创建具有n个元素的deque对象:deque<int>d(10)//创建具有10个整型元素的deque对象d。

③:创建具有n个元素的deque对象并赋初值:deque<int>d(10,8);10个整型元素的deque对象每个元素值为8。

2.插入元素

①:使用push_back()从尾部插入元素,会不断扩张队列。

②:使用push_front()从头部插入元素,其余元素后移。

③:d.insert(q.begin()+k,x)//从中间k位置插入元素x。

3.遍历元素

①:以数组形式遍历:for(int i=0;i<d.size();i++) cout<<d[i]<<" ";

②:以前向迭代器的方式遍历:for(it=d.begin();it!=d.end();it++) cout<<*it<<" ";//it为迭代器,声明省略。

③:采用反向迭代器对双端队列容器进行反向遍历。

for(deque<int>::reverse_iterator rit=d.rbegin();rit!=q.rend();rit++) cout<<*rit<<" ";

4.删除元素:从首部、尾部、中间删除,也可以清空双端对列容器。

①:采用pop_front()从头部删除元素。

②:采用pop_back()从尾部删除元素。

③:使用erase()从中间删除元素,其参数是迭代器位置。d.erase(d.begin()+k)。

④:清空deque对象:d.clear()。

deque容器有基本常用操作都在这了,熟悉了这些这个题就是水题了,不过也要看时间复杂度,对于时间复杂度较高的题还是不建议使用stl。

int main()
{
int n,Q,k,p,x;
while(~scanf("%d%d",&n,&Q))
{
deque<int>q;
for(int i=1; i<=n; i++)
{
scanf("%d",&x);
q.push_back(x);
}
while(Q--)
{
scanf("%d",&k);
if(k==1)
{
scanf("%d%d",&k,&x);
q.insert(q.begin()+k-1,x);
}
else if(k==2)
{
scanf("%d",&k);
q.erase(q.begin()+k-1);
}
else
{
scanf("%d",&k);
printf("%d\n",q[k-1]);
}
}
}
return 0;
}

SPOJ - ADALIST,双端队列入门模板!的更多相关文章

  1. 关于双端队列 deque 模板 && 滑动窗口 (自出)

    嗯... deque 即为双端队列,是c++语言中STL库中提供的一个东西,其功能比队列更强大,可以从队列的头与尾进行操作... 但是它的操作与队列十分相似,详见代码1: 1 #include < ...

  2. SPOJ - ADAQUEUE ,双端队列简单运用!

    ADAQUEUE - Ada and Queue 表示这题是学弟带的榜,题还没看完,学弟吐了一句:这不就是双端队列嘛.于是掏出布满尘埃的<曾粽根ACM程序设计>,嗯,确实是裸题,现学现做. ...

  3. 8、泛型程序设计与c++标准模板库2.3双端队列容器

    双端队列容器是一种放松了访问权限的队列.除了从队列的首部和尾部访问元素外,标准的双端队列也支持通过使用下标操作符"[]"进行直接访问. 它提供了直接访问和顺序访问方法.其头文件为& ...

  4. 双端队列(单调队列)poj2823 区间最小值(RMQ也可以)

    Sliding Window Time Limit: 12000MS   Memory Limit: 65536K Total Submissions: 41844   Accepted: 12384 ...

  5. 《算法实战策略》-chaper19-队列、栈和双端队列

    对于计算机专业的学生来说,他们一定会很熟悉一句话:程序设计 = 算法 + 数据结构.而根据笔者的理解,所谓程序设计其实就是为了编程解决实际问题,所谓算法是一种解决问题某种思维的方法,但是思维需要得到编 ...

  6. HDU 6375(双端队列 ~)

    题意是有至多150000个双端队列,400000次简单操作,直接开会导致内存超限,所以用 STL 中的 map 和 deque ,而读入过大已经在题目中有所说明,直接用已经给出的快速读入即可.要注意的 ...

  7. lintcode二叉树的锯齿形层次遍历 (双端队列)

    题目链接: http://www.lintcode.com/zh-cn/problem/binary-tree-zigzag-level-order-traversal/ 二叉树的锯齿形层次遍历 给出 ...

  8. lintcode 滑动窗口的最大值(双端队列)

    题目链接:http://www.lintcode.com/zh-cn/problem/sliding-window-maximum/# 滑动窗口的最大值 给出一个可能包含重复的整数数组,和一个大小为  ...

  9. STL---deque(双端队列)

    Deque是一种优化了的.对序列两端元素进行添加和删除操作的基本序列容器.它允许较为快速地随机访问,但它不像vector 把所有的对象保存在一块连续的内存块,而是采用多个连续的存储块,并且在一个映射结 ...

随机推荐

  1. 前端之Html元素的分类

    一.html元素可分为三大类:块元素.内联元素.可变元素 1.块元素: 常见块状元素:div,p,ul,ol,li,dl,dt,dd,form,hr,table,tr,td,h1-h6,filedse ...

  2. ABC时间管理法

    名称 ABC时间管理法 属于 事务优先顺序法的“鼻祖” 做法 将待办的事项按照又重要到轻的顺序划分为A,B,C三个等级,然后按照事项的重要等级依据完成任务的做事方法. 特点 使学习.工作和生活等活动在 ...

  3. JavaEE汇总

    1.简述Spring. a)      Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架,其目的是解决企业应用开发的复杂性,能够使用基本的JavaBean代替EJB,并提供了 ...

  4. Longest Increasing Subsequence的两种算法

    问题描述:给出一个序列a1,a2,a3,a4,a5,a6,a7-.an,求它的一个子序列(设为s1,s2,-sn),使得这个子序列满足这样的性质,s1<s2<s3<-<sn并且 ...

  5. strophe.js 插件 XMPP openfire

    参考资料:http://strophe.im/strophejs/ https://github.com/strophe/strophejs-plugins http://amazeui.org/ 最 ...

  6. Cannot fetch index base URL https://pypi.python.org/pypi/ 解决方法

    vi /etc/resolv.conf # Dynamic resolv.conf(5) file for glibc resolver(3) generated by resolvconf(8) # ...

  7. 鼠标点击后的CSS3跑马灯效果

    代码: CSS: /*旋转木马*/ #rotate_container li { width: 128px; box-shadow: 0 1px 3px rgba(0, 0, 0, .5); posi ...

  8. UVA 1664 Conquer a New Region (Kruskal,贪心)

    题意:在一颗树上要求一个到其他结点容量和最大的点,i,j之前的容量定义为i到j的路径上的最小边容量. 一开始想过由小到大的去分割边,但是很难实现,其实换个顺序就很容易做了,类似kruskal的一个贪心 ...

  9. leetcode_1053. Previous Permutation With One Swap

    1053. Previous Permutation With One Swap https://leetcode.com/problems/previous-permutation-with-one ...

  10. Navicat 复制多条数据