1 / 1 / 1
Регистрация: 20.09.2014
Сообщений: 310
1

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

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

Author24 — интернет-сервис помощи студентам
таким путем добавляю новую запись в очередь:
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
Ответы с готовыми решениями:

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

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

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

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

1
1 / 1 / 1
Регистрация: 20.09.2014
Сообщений: 310
03.10.2014, 18:49  [ТС] 2
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
03.10.2014, 18:49
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
03.10.2014, 18:49
Помогаю со студенческими работами здесь

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

Новые блоги и статьи
Какой язык программировани­я лучший для разработки нейронных сетей
InfoMaster 20.01.2025
В современном мире технологий искусственные нейронные сети становятся неотъемлемой частью множества инновационных решений, от распознавания речи до автоматического управления транспортными. . .
Как подключить JavaScript файл в другом JavaScript файле
InfoMaster 20.01.2025
В современной веб-разработке организация кодовой базы играет ключевую роль в создании масштабируемых и поддерживаемых приложений. Модульность и правильное структурирование кода стали неотъемлемыми. . .
Как откатить изменения в исходниках, не внесенные в Git
InfoMaster 20.01.2025
При работе с системой контроля версий Git разработчики часто сталкиваются с необходимостью отменить внесенные изменения в исходном коде. Особенно актуальной становится ситуация, когда изменения еще. . .
В чем разница между px, in, mm, pt, dip, dp, sp
InfoMaster 20.01.2025
В мире цифрового дизайна и разработки интерфейсов правильный выбор единиц измерения играет ключевую роль в создании качественного пользовательского опыта. История развития систем измерений для. . .
Как изменить адрес удалённого репозитория (origin) в Git
InfoMaster 20.01.2025
В терминологии Git термин origin является стандартным именем для основного удаленного репозитория, с которым взаимодействует локальная копия проекта. Когда разработчик клонирует репозиторий с. . .
Как переместить последние коммиты в новую ветку (branch) в Git
InfoMaster 20.01.2025
При работе над проектом часто возникают ситуации, когда необходимо изолировать определенные изменения от основной линии разработки. Это может быть связано с экспериментальными функциями, исправлением. . .
Как вернуть результат из асинхронной функции в JavaScript
InfoMaster 20.01.2025
Асинхронное программирование представляет собой фундаментальную концепцию в JavaScript, которая позволяет выполнять длительные операции без блокировки основного потока выполнения программы. В. . .
Какой локальный веб-сервер выбрать
InfoMaster 19.01.2025
В современной веб-разработке локальные веб-серверы играют ключевую роль, предоставляя разработчикам надежную среду для создания, тестирования и отладки веб-приложений без необходимости использования. . .
Почему планшеты и iPad уже не так популярны, как раньше
InfoMaster 19.01.2025
Эра революционных инноваций История планшетов началась задолго до того, как эти устройства стали привычными спутниками нашей повседневной жизни. В начале 1990-х годов появились первые прототипы,. . .
Как самому прошить BIOS ноутбука
InfoMaster 19.01.2025
BIOS (Basic Input/ Output System) представляет собой важнейший компонент любого компьютера или ноутбука, который обеспечивает базовое взаимодействие между аппаратным и программным обеспечением. . .
Какой Linux выбрать для домашнего компьютера
InfoMaster 19.01.2025
Современные реалии выбора операционной системы В современном мире выбор операционной системы для домашнего компьютера становится все более важным решением, которое может существенно повлиять на. . .
Как объединить два словаря одним выражением в Python
InfoMaster 19.01.2025
В мире программирования на Python работа со словарями является неотъемлемой частью разработки. Словари представляют собой мощный инструмент для хранения и обработки данных в формате "ключ-значение". . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru