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

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

29.09.2014, 12:13. Показов 1569. Ответов 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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
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
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
03.10.2014, 18:49
Помогаю со студенческими работами здесь

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

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

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

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


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

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