Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/8: Рейтинг темы: голосов - 8, средняя оценка - 5.00
1 / 1 / 1
Регистрация: 20.09.2014
Сообщений: 310

Удаление элемента из очереди по срабатыванию условия

29.09.2014, 12:13. Показов 1678. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
таким путем добавляю новую запись в очередь:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
void Add(Queue *Q, char kolname, int kolperiod, int kolvrem9) //добавление элемента
{
int value;
int voz;
char *im9;
im9 = kol[i].name;
value = kol[i].period;
voz = kol[i].vrem9;
Q->last->next = new Node;
Q->last = Q->last->next;
Q->last->name = im9; //добавление элемента в конец
Q->last->vrem9 = voz;
Q->last->period = value;
Q->last->next = NULL; //обнуление указателя на следующий элемент
Q->size++;
}
таким образом я удаляю элемент из очереди
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
void Delete(Queue *Q) //удаление элемента
{
Node *tmp = Q->first;
Q->first = Q->first->next; //смещение указателя
Q->size--;
delete tmp;
printf("\nЭлемент удален\n\n");
};
вот моя очередь:
struct Node //описание узла списка
{
char *name;
int period;
int vrem9;
Node *next; //указатель на следующий элемент
};
struct Queue //описание очереди
{
int size; //счетчик размера очереди
Node *first; //указатель на начало очереди
Node *last; //указатель на конец очереди
};
Вот я заполняю свою очередь например
Штрилиц 2 9
Бонд 5 12
Пеньковский 3 6
Хари 7 20
Иванов 10 25
Петров 17 35
Вторая колонка отвечает за время наблюдения в очереди человека, вторая отвечает за максимальное нахождение в очереди.Как человек пронаблюдал он всает в конец очереди, а если максимальное время прошло то полностью выходит из очереди.
вот таким образом я пытаюсь сделать:
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
if(k!=1){
if (Proverka(&Q) == 0){
Add(&Q, *kolname, kolperiod, kolvrem9);
Delete(&Q);
Print(&Q, *kolname, kolperiod, kolvrem9);
system("pause");
}
else
Delete(&Q);
}
k = Size(&Q);
 
 
int Proverka(Queue *Q)
{
Node *tmp = Q->first;
for (i = 0; i < k; i++)
{
z += tmp->vrem9;
if (tmp->period >= z)
{
tmp = tmp->next;
return 0;
}
else
{
tmp = tmp->next;
return 1;
}
}
}
 
int Size(Queue *Q) //размер очереди
{
return Q->size;
}
как мне переделать чтобы он все нормально делал
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.09.2014, 12:13
Ответы с готовыми решениями:

Создание очереди и удаление элемента очереди по усмотрению пользователя
Вот код он создает очередь и должен удалить элемент очереди по усмотрению пользователя проблема заключается в том что при попытки удалить...

Удаление элемента из очереди
И снова я со своими проблемами. решил,пока нет зацепок с теми задачами,что я не могу реализовать пока в программе, сделать остальное. И...

Удаление элемента из очереди
Здравствуйте, проблема с очередями, совсем их не понимаю, перечитал много статей все равно не доходит.( Задание: Удалить каждый второй...

1
1 / 1 / 1
Регистрация: 20.09.2014
Сообщений: 310
03.10.2014, 18:49  [ТС]
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <locale.h>
int p = 0;
int i=0;
int k = 0;
int z = 0;
char *imo;
struct shpion {
    char name[20];
    int period;
    int vrem9;
    shpion *next;
};
struct shpion kol[100];
struct Node //описание узла списка
{
    char *name;
    int period;
    int vrem9;
    Node *next; //указатель на следующий элемент
};
struct Queue //описание очереди
{
    int size; //счетчик размера очереди
    Node *first; //указатель на начало очереди
    Node *last; //указатель на конец очереди
};
void Creation(Queue *Q) //создание очереди
{
    Q->first = new Node;
    Q->first->next = NULL;
    Q->last = Q->first;
    Q->size = 0;
}
void Print(Queue *Q, char kolname, int kolperiod, int kolvrem9)
{
    Node *tmp = Q->first;
    for (i = 0; i < k; i++)
    {
        printf("%s %d %d\n", tmp->next->name, tmp->next->period, tmp->next->vrem9);
        tmp = tmp->next;
    }
}
bool Full(Queue *Q) //проверка очереди на пустоту
{
    if (Q->first == Q->last) return true;
    else return false;
}
void Add(Queue *Q, char kolname, int kolperiod, int kolvrem9) //добавление элемента
{
    int value;
    int voz;
    char *im9;
    im9 = kol[i].name;
    value = kol[i].period;
    voz = kol[i].vrem9;
    Q->last->next = new Node;
    Q->last = Q->last->next;
    Q->last->name = im9; //добавление элемента в конец
    Q->last->vrem9 = voz;
    Q->last->period = value;
    Q->last->next = NULL; //обнуление указателя на следующий элемент
    Q->size++;
    imo = Q->last->name = im9;
}
void Delete(Queue *Q) //удаление элемента
    {
        Node *tmp = Q->first;
        Q->first = Q->first->next; //смещение указателя
        Q->size--;
        delete tmp;
        printf("\nЭлемент удален\n\n");
    };
int Size(Queue *Q) //размер очереди
{
    return Q->size;
}
int Proverka(Queue *Q)
{
    FILE *file;
    Node *tmp = Q->first;
    for (i = 0; i < k; i++)
    {
        file = fopen("output.txt", "a");
        z += tmp->next->period;
        if (tmp->next->vrem9 >= z){
            fprintf(file, "Время %d\n", z - tmp->next->period);
            fprintf(file, "%s-начало наблюдения\n", tmp->next->name);
            if (z - tmp->next->period>0)
                fprintf(file, "%s-конец наблюдения\n", imo);
            return 0;
        }
        else{
            fprintf(file, "Время %d\n", tmp->next->vrem9);
            fprintf(file, "%s-покинул очередь\n", tmp->next->name);
            z =z- tmp->next->period;
            return 1;
        }
        tmp = tmp->next;
    }
}
void Add1(Queue *Q, char kolname, int kolperiod, int kolvrem9) //добавление элемента
{
    Node *tmp = Q->first;
    int value;
    int voz;
    char *im9;
    im9 = tmp->next->name;
    value = tmp->next->period;
    voz = tmp->next->vrem9;
    Q->last->next = new Node;
    Q->last = Q->last->next;
    Q->last->name = im9; //добавление элемента в конец
    Q->last->vrem9 = voz;
    Q->last->period = value;
    Q->last->next = NULL; //обнуление указателя на следующий элемент
    Q->size++;
    imo = Q->last->name = im9;
}
int main(){
    setlocale(LC_ALL, "Russian");
    FILE *file;
    Queue Q;
    Creation(&Q);
    int j = 0;
    int y = 0;
    int z = 0;
    char *kolname;
    int kolperiod;
    int kolvrem9;
    if ((file = fopen("shpion.txt", "r")) == NULL)
    {
        printf("ошибка при прочтении");
        exit(1);
    }
    file = fopen("shpion.txt", "r");
    while (fscanf(file, "%s%d%d", kol[i].name, &(kol[i].period), &(kol[i].vrem9)) != EOF) {
        i++;
    }
    fclose(file);
    p = i;
    for (i = 0; i < p; i++){
        kolname = kol[i].name;
        kolperiod = kol[i].period;
        kolvrem9=kol[i].vrem9;
        Add(&Q, *kolname, kolperiod, kolvrem9);
    }
    k = Size(&Q);
        if (Full(&Q)) fprintf(file,"Очередь пуста");
        else Print(&Q, *kolname, kolperiod, kolvrem9);
            system("pause");
    while(k!=1){
        if (Proverka(&Q) == 0){
            Add1(&Q, *kolname, kolperiod, kolvrem9);
            Delete(&Q);
        }
        else
            Delete(&Q);
        k = Size(&Q);
    }
}
Дан текстовый файл например
A 5 14
B 3 7
C 2 5
D 3 18
первый столбец отвечает за имя, второй за время в очереди, третий столбец за максимальное нахождение в очереди. Как первый пробыл в очереди он встает в конец.
В выходном файле должен быть написан протокол наблюдения вот например из этих данных
Время 0
A-начало наблюдения
Время 7
B-покинул очередь
Время 5
C-покинул очередь
Время 5
D-начало наблюдения
A-конец наблюдения
Время 8
A-начало наблюдения
D-конец наблюдения
Время 13
D-начало наблюдения
A-конец наблюдения
Время 14
A-покинул очередь
Программа нормально работает. Проблема заключается в том, что надо эти время выводить в порядке возрастания, а не в разброс
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
03.10.2014, 18:49
Помогаю со студенческими работами здесь

Удаление элемента из очереди
у меня такая проблема.когда удаляю элемент из очереди то у меня удаляется вся очередь. type ochered = ^ocheredy; ocheredy =...

Удаление элемента из очереди
У меня в функции удаления элемента, удаляется элемент тот, который ввели последним, а надо первый элемент (тот что ввели первым) Как...

Добавление и удаление элемента из очереди
Есть три очереди, с размерностями 13, 19, 19 Когда добавляю элементы в очереди (в конец), я добавляю сразу во все очереди одновременно....

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

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


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru