Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
liMagneto
0 / 0 / 0
Регистрация: 16.02.2014
Сообщений: 11
#1

Контейнер Очередь. Функция удаления - C++

11.05.2014, 16:40. Просмотров 265. Ответов 0
Метки нет (Все метки)

Здравствуйте. Столкнулась с такой проблемой, что не смогла удалить нужные мне элементы из очереди. Не могли бы вы подсказать этот кусок программы? Что я могу делать неправильно?

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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
#include "stdafx.h"
#include "iostream"
#include "conio.h"
#include "queue"
 
using namespace std;
 
struct Abonent 
{
    char surname[40];
    char address[20]; 
    unsigned number;
}; 
 
class Data
{
public:
    queue <Abonent> och; //создание очереди
    Data()
    {
        Abonent a = {"DiCaprio","Wall Street 15",123456};
        och.push(a);
        Abonent b = {"McConaughey","Dallas Street 52",345678};
        och.push(b);
    } // заполнение очереди
    Abonent Enter_data(int i) // заполнение очереди с клавиатуры
    {
        Abonent a; 
        char c;
        cout << endl << "Enter data" << " person\n";
        cout << "surname ";
        cin.getline(a.surname,40);
        cout << "address ";
        cin.getline(a.address,20);
        cout << endl << "Enter telephone number: \n";
        cout <<" Phone number with 6 signs ";
        cin >> a.number;
        cin.get(c);
 
        och.push(a);
        return a;
    };
 
    void Print (Abonent a) // вывод очереди
    {
            printf("%20s ! %20s ! %6d\n",a.surname,a.address,a.number);
            och.pop();
            och.push(a);
    }
    void Sort (Abonent a) // функция удаления с условием (удалить абонентов, чей номер начинается с 3)
    {
        if ((a.number < 400000) && (a.number >= 300000))
            och.pop();
    }
};
int main()
{
    Data d;
    for(int i = 2; i < 5; i++)
    {
        d.Enter_data(i); // ввод данных
    };
    cout << "\nlist of structuress\n!      Surname       !  Address      !\n";
    for(int i = 0; i < 5; i++)
    {
        d.Print(d.och.front()); // вывод на экран
    }
    cout << endl;
    for(int i = 0; i < 5; i++)
    {
        d.Sort(d.och.front()); // удаление
    }
    cout << "Changed structures"<< endl;
    for(int i = 0; i < 5; i++)
    {
        d.Print(d.och.front()); // вывод измененных данных
    }
    cout << endl;
    _getch();
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.05.2014, 16:40     Контейнер Очередь. Функция удаления
Посмотрите здесь:

Функция удаления на С C++
С помощью cin.getline считать все строки файла в контейнер (вектор или очередь) C++
Контейнеры (функция, которая бы помогла отсортировать контейнер List) C++
Циклическая очередь, сбой после удаления/добавления элемента C++
C++ Задача по STL (Создать объект-контейнер, очередь с приоритетом, заполнить ее данными, тип char)
C++ Реализовать очередь с операциями вставки и удаления элементов
Создать контейнер класса с методами включения и удаления строки, очистки текста, подсчета количества символов C++
Какой контейнер выбрать (Нужен массив, с возможностью добавления и удаления элементов)? C++
C++ Очередь, исправить функцию удаления
C++ Двухсторонная очередь (Дек) - удаления элемента
Создать контейнер по типу очередь, состоящий из символов (библиотека STL) C++
C++ Создать очередь, написать функции для добавления/удаления элементов

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru