如何在C++ STL的queue当中查找一个元素?

声明为queue<int>q;待查找元素声明为intnum;... 声明为queue<int> q;待查找元素声明为int num; 展开
 我来答
匿名用户
2013-04-07
展开全部
int i;queue里面没有find,所以自己写一个吧,比如可以用下面这种,一个一个查,把查到的值记录下来。 for(i =0; i < q.size(); i ++){ if(num == q[i]) break;}if(i == q.size()){cout << "num doesn't exist;"<<endl;}else{cout << "num is the "<<i+1<<"th element in queue q!"<<endl;}
匿名用户
2019-08-26
展开全部

如果num的范围已知,且空间足够,那么:

bool flg[size] = {false}; 

每次元素进队时多一步操作:(i为即将入队的值)

q.push(i);

flg[i] = true;

查找的时候只需要参考flg[num]就好。

这样查找比较快,时间复杂度为O(1)。

如果空间不够,或者想知道num在队中的位置,那么把整个队列遍历一遍。

queue<int>tmp; int i=1;

while(!q.empty()){

tmp.push(q.front());

q.pop();

if(tmp.rear==num) cout<<i<<endl;

i++;

}

while(!tmp.empty()){

q.push(tmp.front());

tmp.pop();

}

这样,所有值为num的元素所在的位置都可以知道了。

由于队列是动态的,所占用的空间只会多一点点。但时间复杂度为O(n)。

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
928614527
2017-12-12 · 超过12用户采纳过TA的回答
知道答主
回答量:50
采纳率:0%
帮助的人:18.9万
展开全部
#include<stdio.h> 
#include<iostream>
#include<string> 
#include<malloc.h>
#include<fstream>
#include<vector>
#include<queue>

using namespace std;

void searchQueue(queue<int> q, int searchValue) {
int pos = 0;
bool searchFlag = false;
for(int i=0; i<q.size(); ++i) {
if(q.front() == searchValue && !searchFlag) {
cout << pos;
searchFlag = true;
}
else {
q.push(q.front());
q.pop();
pos++;
}
}
}

int main() {
queue<int> q;
q.push(1);
q.push(2);
q.push(3);
searchQueue(q, 2);
}

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
编程大王
2017-06-18 · TA获得超过922个赞
知道小有建树答主
回答量:979
采纳率:51%
帮助的人:114万
展开全部
queue是队列的意思,好像有一个front方法,可以看看
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
xuning2516
2013-04-09 · TA获得超过643个赞
知道小有建树答主
回答量:607
采纳率:0%
帮助的人:281万
展开全部
//使用algorithm的find函数
#include <algorithm>
#include <queue>
using namespace std;
int main()
{
queue<int> q={1,2,3,4,5,6,7}; //初始化
int num=2; //赋值
auto pos=find(q.cbegin(),q,cend(),num);
if(pos!=q.cend())
{
cout<<"找到该元素"<<endl;
}
else
{
cout<<"未找到该元素"<<endl;
}
}
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 4条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式