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

Класс с использованием list - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Альфа-прозрачность формы http://www.cyberforum.ru/cpp-beginners/thread386332.html
Впрочем, здесь пойдет речь не совсем о альфа-прозрачности формы.. Как можно на C++ осуществить такую вещь: Тоесть альфа-прозрачность верхней части окна, то место между заголовком и началом формы, я незнаю как назвать это, надеюсь меня поймут. Заранее спасибо.;)
C++ Контейнеры, обработка символов Помогите пожалуста, препод написал эту программу и сказал что окромя работы с числами она должна работать с буквами сама прога выводит числа от 10 до 0 в столбик. Помогите модифицировать эту программы для работы с символами. Заранее спасибо template < class Object > class vector { public: explicit vector(int initSize = 0):theSize(initSize), theCapacity(initSize) //explict... http://www.cyberforum.ru/cpp-beginners/thread386326.html
Итератор для бинарного дерева C++
Расскажите, что из себя представляет класс итератор. Какие базовые функции он должен содержать применительно для работы с бинарным деревом? Как вообще он должен быть реализован (код)?
Для данного вещественного x найти значение функции f C++
Для данного вещественного x найти значение следующей функции f, при-нимающей значения целого типа: 0, если x < 0, f(x) = 1, если x принадлежит [0, 1), [2, 3), … , –1, если x принадлежит [1, 2), [3, 4), … . решите пожалуйста эту задачу, с учетом того, что х может принимать дробные значения. Хотя бы просто сам принцип решения с таким условием, алгоритм..
C++ Подскажите, в чём ошибка? http://www.cyberforum.ru/cpp-beginners/thread386316.html
Задание: Записи в линейном списке содержат ключевое поле типа int. Сформировать двунаправленный список. Удалить из него элемент с заданным номером, добавить элемент в начало списка. Вот что у меня получилось: #include "stdafx.h" #include <stdio.h> struct list { int val; list *next,*prev; };
C++ Библиотека <vector> Доброго времени суток... Я недавно столкнулся с библиотекой вектор, когда разбирался с графами. Может мне кто-то объяснить что это и с чем его едят? подробнее

Показать сообщение отдельно
cyt
1 / 1 / 0
Регистрация: 01.10.2010
Сообщений: 47
25.11.2011, 01:00  [ТС]
Вот, рабочий код:
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
#include <iostream>
#include <list>
using namespace std;
 
typedef enum {LOW, NORMAL, HIGH} ElementPriority;
 
typedef struct
{
    string elem;
    ElementPriority priority;
} QueueElement;
 
class QueueWithPriority
{   
    
    public:           
        QueueWithPriority(); 
        ~QueueWithPriority();    
        void PutElementToQueue(const QueueElement&); 
        QueueElement GetElementFromQueue(); 
        void Accelerate(); 
        bool IsEmpty() { return qwp->empty(); }    
    private:            
        list<QueueElement>::iterator iter;     
        list<QueueElement> *qwp;
};
 
QueueWithPriority::QueueWithPriority()
{   
    qwp = new list<QueueElement>;   
    iter = qwp->begin();
}
 
QueueWithPriority::~QueueWithPriority()
{  
    delete qwp;
} 
 
void QueueWithPriority::PutElementToQueue(const QueueElement& element)
{   
    qwp->push_back(element);
}
 
QueueElement QueueWithPriority::GetElementFromQueue()
{ 
    QueueElement el;    
    
    iter = qwp->begin();  
    while(iter != qwp->end()) 
    {   
        if((*iter).priority == HIGH)
        {      
            el = *iter;  
            qwp->erase(iter);   
            return el;   
        }    
        else    
            iter++;   
    }        
    
    iter = qwp->begin();  
    while(iter != qwp->end())
    {     
        if((*iter).priority == NORMAL)
        {      
            el = *iter;      
            qwp->erase(iter);     
            return el;  
        }  
        else      
            iter++; 
    }    
    
    iter = qwp->begin();   
    while(iter != qwp->end())
    {  
        if((*iter).priority == LOW)
        {  
            el = *iter; 
            qwp->erase(iter);  
            return el;    
        }
        else   
            iter++;   
    }
    
    return el; // Фиктивный сценарий
}
 
void QueueWithPriority::Accelerate()
{
    iter = qwp->begin();  
    while(iter != qwp->end()) 
    {   
        if((*iter).priority == LOW)  
            (*iter).priority = HIGH;
        iter++;
    }
}
 
int main()
{
    QueueWithPriority QWP;  
    QueueElement q1 = {"1", HIGH}, 
                 q2 = {"2", LOW},
                 q3 = {"3", NORMAL}, 
                 q4 = {"4", HIGH},
                 q5 = {"5", NORMAL},
                 temp;   
    
    QWP.PutElementToQueue(q1);
    QWP.PutElementToQueue(q2);  
    QWP.PutElementToQueue(q3);
    QWP.PutElementToQueue(q4);
    QWP.PutElementToQueue(q5); 
    
    QWP.Accelerate();      
    
    while(!QWP.IsEmpty())  
    {       
        temp = QWP.GetElementFromQueue(); 
        cout << temp.elem.c_str() << "  ";    
    } 
    cout << endl;    
    
    return 0;
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru