Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.65/40: Рейтинг темы: голосов - 40, средняя оценка - 4.65
6 / 6 / 0
Регистрация: 06.10.2010
Сообщений: 122
1

Поиск элемента в queue

05.01.2012, 11:33. Показов 8297. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Доброе утро! Такой вопрос, можно ли как то осуществлять поиск элемента в очереди? В алгоритмах нашел функцию поиска find, но у queue нет итератора....Может кто знает алгоритм поиска именно в очереди?Буду признателен.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
05.01.2012, 11:33
Ответы с готовыми решениями:

Удаление элемента из очереди (queue) по указанному индексу
Реализовать удаление элемента из очереди по указанному индексу(queue)

Вставка элемента в заданную позицию, удаление элемента по заданной позиции, поиск заданного элемента
Добавить в класс "Односвязный список" следующие функции: вставка элемента в заданную позицию,...

Очереди Queue: получение текущего элемента
Как получить текущий элемент в очереди без его удаления: Например: элемент очереди у меня список...

Удаление нужного элемента из очереди Queue
Добрый день! Имеется коллекция queue и из нее требуется удалить искомый элемент. Например, удалить...

3
2554 / 1319 / 178
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
05.01.2012, 11:44 2
queue не подразумевает свободное разгуливание по самой себе. Выпихивать в другую очередь и искать.
1
программист С++
860 / 600 / 147
Регистрация: 19.12.2010
Сообщений: 2,014
05.01.2012, 13:28 3
если сильно хочется, то можно вспомнить что queue это адаптер контейнера, следовательно получить сам контейнер и делать что хотим)
C++
1
2
std::queue<int> f;
f._Get_container();
вряд ли конечно этот метод предусмотрен стандартом, но в VS он есть)
0
Эксперт С++
5055 / 3115 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
06.01.2012, 12:08 4
А чтобы по стандарту, можно вот такую простенькую функцию написать:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
#include <iostream>
#include <vector>
#include <list>
#include <queue>
#include <deque>
#include <algorithm>
#include <iterator>
 
template<typename T, typename Cont, typename FwdIter>
void queue_to_container(const std::queue<T, Cont>& q, FwdIter iter)
{
    typedef T value_type;
    
    std::queue<T> copy_q = q;
    
    while (!copy_q.empty())
    {
        *iter++ = copy_q.front();
        
        copy_q.pop();
    }
}
 
int main()
{
    std::queue<int> q;
    
    q.push(10);
    q.push(20);
    q.push(30);
    
    std::vector<int> vec(3);
    
    queue_to_container(q, vec.begin());
    
    std::list<int> lst;
    
    queue_to_container(q, std::back_inserter(lst));
    
    std::cout << "Vector: ";
    std::copy(vec.begin(), vec.end(), std::ostream_iterator<int>(std::cout, "  "));
    std::cout << std::endl;
    
    std::cout << "List: ";
    std::copy(lst.begin(), lst.end(), std::ostream_iterator<int>(std::cout, "  "));
    std::cout << std::endl;
    
    std::cout << "Queue: ";
    std::cout << q.front() << "  ";
    q.pop();
    std::cout << q.front() << "  ";
    q.pop();
    std::cout << q.front() << std::endl;
    q.pop();
    
    return 0;
}
0
06.01.2012, 12:08
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
06.01.2012, 12:08
Помогаю со студенческими работами здесь

Разница между finalization queue и freachable queue
Всем привет, все как-то никак не могу понять, в чем разница

Разница между queue.synchronized и concurrent queue
По сути 2 коллекции потокобезопасные, что лучше использовать? Queue que =...

Переполнение Queue, методы оптимизации Queue
Доброго времени суток. Я тут планирую пенгатон взять под контроль.:- StreamReader...

Queue vs Queue.Synchronized vs ConcurrentQueue
Ситуация такова, что один поток постоянно толкает в очередь объекты (Enqueue), а второй забирает...

Поиск минимального значения элемента и определение порядкового номера наименьшего элемента
Необходимо написать программу, формирующую рандомный одномерный массив, а после определяющую...

Поиск минимального значения элемента и определение порядкового номера наименьшего элемента
Дана непустая последовательность различных натуральных чисел. Определить порядковый номер...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru