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

Какой контейнер в STL и для чего эффективнее использовать?

14.07.2015, 17:38. Показов 10267. Ответов 21
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Какой контейнер в STL и для чего эффективнее использовать? И почему
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.07.2015, 17:38
Ответы с готовыми решениями:

Какой контейнер для чего использовать?
для чего какой контейнер эффективней использовать? vector- list- map- set- queue- stack-

Какой вариант кода правильнее и эффективнее использовать?
Первый или второй вариант, и вообще есть ли принципиальная разница, между ними? List<string> files = new List<string>(); ...

Какой контейнер STL выбрать?
Во входном потоке (FILE*) дано множество точек. Найти пару точек, расстояние между которыми минимально. Ввод и вывод в произвольной форме....

21
Эксперт С++
 Аватар для Avazart
8488 / 6155 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
14.07.2015, 22:13
Джосаттис Н. "Стандартная библиотека C++ справочное руководство", 2-е изд. - 2014
Мейерс С. "Эффективное использование STL" 2002
0
Неэпический
 Аватар для Croessmah
18149 / 10731 / 2067
Регистрация: 27.09.2012
Сообщений: 27,033
Записей в блоге: 1
14.07.2015, 22:22
Кликните здесь для просмотра всего текста
14
15.07.2015, 13:04

Не по теме:

Croessmah, схоронил.

0
81 / 25 / 19
Регистрация: 27.10.2014
Сообщений: 420
15.07.2015, 13:39
Спасибо большое!
0
Эксперт С++
 Аватар для Mr.X
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
15.07.2015, 14:55
Croessmah, а источник можно узнать?
0
Неэпический
 Аватар для Croessmah
18149 / 10731 / 2067
Регистрация: 27.09.2012
Сообщений: 27,033
Записей в блоге: 1
15.07.2015, 14:59
Mr.X, на хабре есть http://m.habrahabr.ru/company/... og/194726/
Но, конкретно в этой теме рисунок из другой темы. Вспомнил, что уже ввкладывали на форуме эту схему, нашел и поставил сюда )))
0
81 / 25 / 19
Регистрация: 27.10.2014
Сообщений: 420
15.07.2015, 15:00
Цитата Сообщение от Mr.X Посмотреть сообщение
а источник можно узнать?
Тык. Думаю отсюда, просто в виде таблицы сделано для удобства.
0
15.07.2015, 15:00

Не по теме:

upd: В пути m. - я прост со смартфона :-)

0
Игогошка!
 Аватар для ct0r
1801 / 708 / 44
Регистрация: 19.08.2012
Сообщений: 1,367
15.07.2015, 15:22
Одно печально - там, где выбор контейнера действительно имеет важное значение для решения задачи, эта информация - лишь 20-30% от всей той, которую в принципе нужно рассматривать для принятия хорошего решения.
0
Неэпический
 Аватар для Croessmah
18149 / 10731 / 2067
Регистрация: 27.09.2012
Сообщений: 27,033
Записей в блоге: 1
15.07.2015, 16:37
ct0r, всего не перечислить
0
Эксперт С++
 Аватар для Avazart
8488 / 6155 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
15.07.2015, 16:55
Ну поэтому стоить читать/знать каждый контейнер ...

Добавлено через 1 минуту
Ну и еще знать про boost/multi_index
0
Эксперт С++
 Аватар для Mr.X
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
24.07.2015, 13:05
Цитата Сообщение от Croessmah Посмотреть сообщение
на хабре
Кстати, хабровские мужики немного погорячились при конвертации этой схемы под новый стандарт. Ответы "не отсортирован по ключу" и "не нужно итерировать из конца в начало" не ведут к хеш-таблицам.
0
Эксперт С++
 Аватар для Mr.X
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
27.07.2015, 10:52
С детства блок-схемы не люблю. Моя программа для выбора контейнера:
Часть 1.
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
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
/////////////////////////////////////////////////////////////////////////////////////////
#include <algorithm>
#include <cctype>
#include <iostream>
#include <iterator>
#include <map>
#include <memory>
#include <numeric>
#include <set>
#include <string>
/////////////////////////////////////////////////////////////////////////////////////////
typedef std::string             T_str;
typedef std::set    < int   >   T_numbers;
/////////////////////////////////////////////////////////////////////////////////////////
enum    T_container
{
    FORWARD_LIST,
    LIST,
    ARRAY,
 
    VECTOR,
    STRING,
    DEQUE,
 
    UNORDERED_MAP,
    UNORDERED_SET,
    UNORDERED_MULTIMAP,
 
    UNORDERED_MULTISET,
    SET,
    MAP,
 
    MULTISET,
    MULTIMAP,
    STACK,
 
    QUEUE,
    PRIORITY_QUEUE
};
/////////////////////////////////////////////////////////////////////////////////////////
typedef std::set    < T_container               >   T_containers;
typedef std::map    < T_str,    T_containers    >   T_containers_of_answer;
/////////////////////////////////////////////////////////////////////////////////////////
template< typename  TT_set >
TT_set  &   operator-=
    (
        TT_set          &   L,
        TT_set  const   &   R
    )
{
    TT_set  res_set;
 
    std::set_difference
        (
            L.begin  (),
            L.end    (),
            R.begin  (),
            R.end    (),
 
            std::inserter
                (
                    res_set,
                    res_set.begin()
                )
        );
 
    return  L   =   res_set;
}
/////////////////////////////////////////////////////////////////////////////////////////
template
    <
        typename    TT_set,
        typename    TT_elem
    >
TT_set  &   operator-=
    (
        TT_set              &   L,
        TT_elem     const   &   R
    )
{
    L.erase( R );
    return  L;
}
/////////////////////////////////////////////////////////////////////////////////////////
template
    <
        typename    TT_set,
        typename    TT__set_or_elem
    >
TT_set  operator-
    (
        TT_set              const   &   L,
        TT__set_or_elem     const   &   R
    )
{
    auto    res     =   L;
    return  res     -=  R;
}
/////////////////////////////////////////////////////////////////////////////////////////
template
    <
        typename    TT_set,
        typename    TT_elem
    >
TT_set  &   operator+=
    (
        TT_set              &   L,
        TT_elem     const   &   R
    )
{
    L.insert( R );
    return  L;
}
/////////////////////////////////////////////////////////////////////////////////////////
template< typename  TT_set >
TT_set  &   operator+=
    (
        TT_set          &   L,
        TT_set  const   &   R
    )
{
    TT_set  res_set;
 
    std::set_union
        (
            L.begin  (),
            L.end    (),
            R.begin  (),
            R.end    (),
 
            std::inserter
                (
                    res_set,
                    res_set.begin()
                )
        );
 
    return  L   =   res_set;
}
/////////////////////////////////////////////////////////////////////////////////////////
template
    <
        typename    TT_set,
        typename    TT__set_or_elem
    >
TT_set  operator+
    (
        TT_set              const   &   L,
        TT__set_or_elem     const   &   R
    )
{
    auto    res     =   L;
    return  res     +=  R;
}
/////////////////////////////////////////////////////////////////////////////////////////
template< typename  TT_set >
TT_set  &   operator*=
    (
        TT_set          &   L,
        TT_set  const   &   R
    )
{
    TT_set  res_set;
 
    std::set_intersection
        (
            L.begin  (),
            L.end    (),
            R.begin  (),
            R.end    (),
 
            std::inserter
                (
                    res_set,
                    res_set.begin()
                )
        );
 
    return  L   =   res_set;
}
/////////////////////////////////////////////////////////////////////////////////////////
template< typename  TT_set >
TT_set  operator*
    (
        TT_set  const   &   L,
        TT_set  const   &   R
    )
{
    auto    res     =   L;
    return  res     *=  R;
}
/////////////////////////////////////////////////////////////////////////////////////////
template< typename  TT_set >
bool    is_subset_of
    (
        TT_set  const   &   L,
        TT_set  const   &   R
    )
{
    return  std::includes
                (
                    R.begin     (),
                    R.end       (),
                    L.begin     (),
                    L.end       ()
                );
}
/////////////////////////////////////////////////////////////////////////////////////////
struct  T_containers_data
{
    //-----------------------------------------------------------------------------------
    T_containers    lists_containers_;
    T_containers    arrays_containers_;
    T_containers    hash_containers_;
 
    T_containers    tree_containers_;
    T_containers    adapters_;
    T_containers    key_containers_;
 
    T_containers    all_containers_;
    T_containers    lists_and_deque_containers_;
    T_containers    not_multi_key_containers_;
 
    T_containers    sets_containers_;
    T_containers    lists_and_deque_and_hash_containers_;
    T_containers    vector_and_string_containers_;
 
    T_containers    lists_and_hash_containers_;
    T_containers    array_containers_;
    T_containers    vector_deque_string_containers_;
 
    T_containers    not_key_containers_;
    T_containers    lists_and_key_containers_;
    T_containers    array_and_vector_and_string_containers_;
 
    T_containers    forward_list_and_deque_and_hash_containers_;
    T_containers    not_forward_list_containers_;
    T_containers    not_arrays_containers_;
    //-----------------------------------------------------------------------------------
    T_containers_data()
    {
        //===============================================================================
        lists_containers_               .insert( FORWARD_LIST           );
        lists_containers_               .insert( LIST                   );
        //===============================================================================
        arrays_containers_              .insert( ARRAY                  );
        arrays_containers_              .insert( VECTOR                 );
        arrays_containers_              .insert( DEQUE                  );
        arrays_containers_              .insert( STRING                 );
        //===============================================================================
        hash_containers_                .insert( UNORDERED_SET          );
        hash_containers_                .insert( UNORDERED_MAP          );
        hash_containers_                .insert( UNORDERED_MULTISET     );
        hash_containers_                .insert( UNORDERED_MULTIMAP     );
        //===============================================================================
        tree_containers_                .insert( SET                    );
        tree_containers_                .insert( MAP                    );
        tree_containers_                .insert( MULTISET               );
        tree_containers_                .insert( MULTIMAP               );
        //===============================================================================
        adapters_                       .insert( STACK                  );
        adapters_                       .insert( QUEUE                  );
        adapters_                       .insert( PRIORITY_QUEUE         );
        //===============================================================================
        not_multi_key_containers_       .insert( SET                    );
        not_multi_key_containers_       .insert( MAP                    );
        not_multi_key_containers_       .insert( UNORDERED_SET          );
        not_multi_key_containers_       .insert( UNORDERED_MAP          );
        //===============================================================================
        sets_containers_                .insert( SET                    );
        sets_containers_                .insert( MULTISET               );
        sets_containers_                .insert( UNORDERED_SET          );
        sets_containers_                .insert( UNORDERED_MULTISET     );
        //===============================================================================
        array_containers_               .insert( ARRAY                  );
        //===============================================================================
        not_forward_list_containers_    .insert( LIST                   );
        //===============================================================================
        vector_and_string_containers_   .insert( VECTOR                 );
        vector_and_string_containers_   .insert( STRING                 );
        //===============================================================================
        key_containers_                                 =       hash_containers_
                                                            +   tree_containers_;
        //===============================================================================
        all_containers_                                 =       lists_containers_
                                                            +   arrays_containers_
                                                            +   key_containers_
                                                            +   adapters_;
        //===============================================================================
        lists_and_deque_containers_                     =       lists_containers_
                                                            +   DEQUE;
        //===============================================================================
        lists_and_deque_and_hash_containers_            =       lists_and_deque_containers_
                                                            +   hash_containers_;
        //===============================================================================
        lists_and_hash_containers_                      =       lists_containers_
                                                            +   hash_containers_;
        //===============================================================================
        vector_deque_string_containers_                 =       arrays_containers_
                                                            -   array_containers_;
        //===============================================================================
1
Эксперт С++
 Аватар для Mr.X
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
27.07.2015, 10:54
Часть 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
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
        not_key_containers_                             =       all_containers_
                                                            -   key_containers_
                                                            -   adapters_;
        //===============================================================================
        lists_and_key_containers_                          =       lists_containers_
                                                                +   key_containers_;
        //===============================================================================
        array_and_vector_and_string_containers_         =       arrays_containers_
                                                            -   DEQUE;
        //===============================================================================
        forward_list_and_deque_and_hash_containers_     =       lists_and_deque_and_hash_containers_
                                                            -   LIST;
        //===============================================================================
        not_arrays_containers_                          =       all_containers_
                                                            -   arrays_containers_;
        //===============================================================================
    }
};
/////////////////////////////////////////////////////////////////////////////////////////
const   T_str   ANSWER_YES          =   "1) да";
const   T_str   ANSWER_NO           =   "2) нет";
/////////////////////////////////////////////////////////////////////////////////////////
const   T_str   TYPE_NAME_BUILT_IN  =   "встроенный";
const   T_str   TYPE_NAME_CHAR      =   "char";
const   T_str   TYPE_NAME_BOOL      =   "bool";
const   T_str   USER_DEFINED_TYPE   =   "пользовательский";
/////////////////////////////////////////////////////////////////////////////////////////
class   T_question
{
    //-----------------------------------------------------------------------------------
    T_str   question_text_;
    //-----------------------------------------------------------------------------------
public:
    //-----------------------------------------------------------------------------------
    typedef unsigned long   T_answer_num;
    //-----------------------------------------------------------------------------------
    T_question( T_str   const   &   question_text )
        :
        question_text_( question_text )
    {}
    //-----------------------------------------------------------------------------------
    virtual
    ~T_question()
    {}
    //-----------------------------------------------------------------------------------
    virtual
    bool    there_are_superfluous_containers_in
        ( T_containers  const   &   containers )                                    const   =   0;
    //-----------------------------------------------------------------------------------
    virtual
    int     weight()                                                                const   =   0;
    //-----------------------------------------------------------------------------------
    virtual
    bool    there_are_suitable_containers_to_choose_from_in
        ( T_containers   const   &   containers )                                   const   =   0;
    //-----------------------------------------------------------------------------------
    virtual
    bool    successfully_ask_question_and_set_selected_containers_and_write_to_answers_history
        (
            T_containers    &   containers,
            T_str           &   answers_history
        )                                                                           const
    {
        T_answer_num    answer_num  =   0;
 
        bool            bool_res    =   successfully_for_containers_input_and_set_answer_num
                                            (
                                                containers,
                                                answer_num
                                            );
 
        if( bool_res )
        {
            modify_selected_containers_for_answer_num
                (
                    containers,
                    answer_num
                );
 
            answers_history.append
                (
                    get_text_of_question_and_answer_with_num( answer_num )
                );
        }//if
 
        return  bool_res;
    }
    //-----------------------------------------------------------------------------------
protected:
    //-----------------------------------------------------------------------------------
    bool    there_are_suitable_containers_in
        ( T_containers   const   &   containers )                                   const
    //
    {
        return  !   (
                            containers
                        *   main_containers()
                    )
                    .empty();
    }
    //-----------------------------------------------------------------------------------
    T_str   question_text               ()                                          const
    {
        return  question_text_;
    }
    //-----------------------------------------------------------------------------------
private:
    //-----------------------------------------------------------------------------------
    virtual
    T_containers    main_containers     ()                                          const   =   0;
    //-----------------------------------------------------------------------------------
    virtual
    T_str   get_text_of_question_and_answer_with_num( int  answer_num )             const   =   0;
    //-----------------------------------------------------------------------------------
    bool    successfully_for_containers_input_and_set_answer_num
        (
            T_containers    const   &   containers,
            T_answer_num            &   answer_num
        )                                                                           const
    {
        bool        bool_res    =   false;
        T_numbers   answers_numbers;
        T_str       answers_texts;
 
        for_containers_set_numbers_and_texts_of_not_empty_answers
            (
                containers,
                answers_numbers,
                answers_texts
            );
 
        do
        {
            std::cout   <<  std::endl
                        <<  question_text()
                        <<  std::endl
                        <<  answers_texts;
 
            std::cout   <<  "Введите номер ответа (чтобы пропустить вопрос - просто нажмите Enter): ";
            T_str   s;
            std::cin.sync();
            getline( std::cin,  s );
            bool_res    =   !s.empty();
 
            if( !bool_res )
            {
                break;
            }
 
            try
            {
                answer_num  =   std::stoul( s );
            }
            catch(...)
            {
                continue;
            }
        }
        while   (
                    answers_numbers.count( answer_num )     ==  0
                );
 
        return  bool_res;
    }
    //-----------------------------------------------------------------------------------
    virtual
    void    modify_selected_containers_for_answer_num
        (
            T_containers    &   containers,
            T_answer_num        answer_num
        )                                                                           const   =   0;
    //-----------------------------------------------------------------------------------
    virtual
    void    for_containers_set_numbers_and_texts_of_not_empty_answers
        (
            T_containers    const   &   containers,
            T_numbers               &   numbers,
            T_str                   &   answers_texts
        )                                                                           const  =   0;
    //-----------------------------------------------------------------------------------
};
/////////////////////////////////////////////////////////////////////////////////////////
typedef std::shared_ptr     < T_question    >   T_question_ptr;
/////////////////////////////////////////////////////////////////////////////////////////
struct  T_question_ptrs_comp
{
    //-----------------------------------------------------------------------------------
    bool    operator()
        (
            T_question_ptr  L_ptr,
            T_question_ptr  R_ptr
        )   const
    {
        return      L_ptr->weight()
                >   R_ptr->weight();
    }
    //-----------------------------------------------------------------------------------
};
/////////////////////////////////////////////////////////////////////////////////////////
typedef std::multiset< T_question_ptr,   T_question_ptrs_comp   >   T_question_ptrs;
/////////////////////////////////////////////////////////////////////////////////////////
class   T_yes_question  :   public  T_question
{
    //-----------------------------------------------------------------------------------
    T_containers    containers_for_selecting_;
    T_containers    containers_yes_;
    int             weight_;
    //-----------------------------------------------------------------------------------
public:
    //-----------------------------------------------------------------------------------
    enum    T_weight
    {
        ADAPTERS_QUESTION_WEIGHT                =   200,
        QUICK_BINARY_SEARCH_QUESTION_WEIGHT     =   100
    };
    //-----------------------------------------------------------------------------------
    T_yes_question
        (
            T_str           const   &   question_text,
            T_containers    const   &   containers_for_selecting,
            T_containers    const   &   containers_yes,
            int                         weight
        )
        :
        T_question                  ( question_text             ),
        containers_for_selecting_   ( containers_for_selecting  ),
        containers_yes_             ( containers_yes            ),
        weight_                     ( weight                    )
    {}
    //-----------------------------------------------------------------------------------
    virtual
    ~T_yes_question()
    {}
    //-----------------------------------------------------------------------------------
    virtual
    bool    there_are_superfluous_containers_in
        ( T_containers  const   &   containers )                                    const
    {
        return  !   is_subset_of
                        (
                            containers,
                            containers_for_selecting_
                        );
    }
    //-----------------------------------------------------------------------------------
    virtual
    int     weight()                                                                const
    {
        return  weight_
                    ?   weight_
                    :   main_containers().size();
    }
    //-----------------------------------------------------------------------------------
    virtual
    bool    there_are_suitable_containers_to_choose_from_in
        ( T_containers   const   &   containers )                                   const
    {
        return      there_are_suitable_containers_in( containers )
 
                &&  !is_subset_of
                        (
                            containers,
                            containers_yes()
                        );
    }
    //-----------------------------------------------------------------------------------
protected:
    //-----------------------------------------------------------------------------------
    T_containers    containers_yes()                                                const
    {
        return  containers_yes_;
    }
    //-----------------------------------------------------------------------------------
private:
    //-----------------------------------------------------------------------------------
    virtual
    T_containers    main_containers()                                               const
    {
        return  containers_yes();
    }
    //-----------------------------------------------------------------------------------
};
/////////////////////////////////////////////////////////////////////////////////////////
class   T_yes_or_not_relevant_question   :   public  T_yes_question
{
    //-----------------------------------------------------------------------------------
public:
    //-----------------------------------------------------------------------------------
    T_yes_or_not_relevant_question
        (
            T_str           const   &   question_text,
            T_containers    const   &   containers_for_selecting,
            T_containers    const   &   containers_yes,
            int                         weight  =   0
        )
        :
        T_yes_question
            (
                question_text,
                containers_for_selecting,
                containers_yes,
1
Эксперт С++
 Аватар для Mr.X
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
27.07.2015, 10:56
Часть 3
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
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
                weight
            )
    {}
    //-----------------------------------------------------------------------------------
    virtual
    ~T_yes_or_not_relevant_question()
    {}
    //-----------------------------------------------------------------------------------
private:
    //-----------------------------------------------------------------------------------
    virtual
    T_str   get_text_of_question_and_answer_with_num( int  answer_num )             const
    {
        return      "\n"
                +   question_text()
                +   "\t"
                +   ANSWER_YES;
    }
    //-----------------------------------------------------------------------------------
    virtual
    void    modify_selected_containers_for_answer_num
        (
            T_containers    &   containers,
            T_answer_num        answer_num
        )                                                                           const
    {
        containers  *=  containers_yes();
    }
    //-----------------------------------------------------------------------------------
    virtual
    void    for_containers_set_numbers_and_texts_of_not_empty_answers
                (
                    T_containers    const   &   containers,
                    T_numbers               &   numbers,
                    T_str                   &   answers_texts
                )                                                                   const
    {
        numbers.insert(1);
 
        answers_texts.append
            (
                "\t"    +   ANSWER_YES  +   "\n"
            );
    }
    //-----------------------------------------------------------------------------------
};
/////////////////////////////////////////////////////////////////////////////////////////
class   T_yes_or_not_question   :   public  T_yes_question
{
    //-----------------------------------------------------------------------------------
public:
    //-----------------------------------------------------------------------------------
    T_yes_or_not_question
        (
            T_str           const   &   question_text,
            T_containers    const   &   containers_for_selecting,
            T_containers    const   &   containers_yes,
            int                         weight  =   0
        )
        :
        T_yes_question
            (
                question_text,
                containers_for_selecting,
                containers_yes,
                weight
            )
    {}
    //-----------------------------------------------------------------------------------
    virtual
    ~T_yes_or_not_question()
    {}
    //-----------------------------------------------------------------------------------
private:
    //-----------------------------------------------------------------------------------
    virtual
    T_str   get_text_of_question_and_answer_with_num( int  answer_num )             const
    {
        return      "\n"
                +   question_text()
                +   "\t"
                +   (
                        answer_num  ==  1
                            ?   ANSWER_YES
                            :   ANSWER_NO
                    );
    }
    //-----------------------------------------------------------------------------------
    virtual
    void    modify_selected_containers_for_answer_num
        (
            T_containers    &   containers,
            T_answer_num        answer_num
        )                                                                           const
    {
        answer_num  ==  1
            ?   containers  *=  containers_yes()
            :   containers  -=  containers_yes();
    }
    //-----------------------------------------------------------------------------------
    virtual
    void    for_containers_set_numbers_and_texts_of_not_empty_answers
        (
            T_containers    const   &   containers,
            T_numbers               &   numbers,
            T_str                   &   answers_texts
        )                                                                           const
    {
        numbers.insert(1);
        numbers.insert(2);
 
        answers_texts.append
            (
                        "\t"    +   ANSWER_YES  +   "\n"
                    +   "\t"    +   ANSWER_NO   +   "\n"
            );
    }
    //-----------------------------------------------------------------------------------
};
/////////////////////////////////////////////////////////////////////////////////////////
class   T_switch_question   :   public  T_question
{
    //-----------------------------------------------------------------------------------
    T_containers_of_answer  containers_of_answer_;
    //-----------------------------------------------------------------------------------
public:
    //-----------------------------------------------------------------------------------
    T_switch_question
        (
            T_str   const   &   question_text,
            T_str   const   &   answer_A            ,   T_containers    const   &   containers_A,
            T_str   const   &   answer_B    =   ""  ,   T_containers    const   &   containers_B    =   T_containers(),
            T_str   const   &   answer_C    =   ""  ,   T_containers    const   &   containers_C    =   T_containers(),
            T_str   const   &   answer_D    =   ""  ,   T_containers    const   &   containers_D    =   T_containers()
        )
        :
        T_question( question_text )
    {
        containers_of_answer_[ answer_A ]       =   containers_A;
 
        if  (
                !answer_B.empty()
            )
        {
            containers_of_answer_[ answer_B ]   =   containers_B;
        }
 
        if  (
                !answer_C.empty()
            )
        {
            containers_of_answer_[ answer_C ]   =   containers_C;
        }
 
        if  (
                !answer_D.empty()
            )
        {
            containers_of_answer_[ answer_D ]   =   containers_D;
        }
    }
    //-----------------------------------------------------------------------------------
    virtual
    ~T_switch_question()
    {}
    //-----------------------------------------------------------------------------------
    virtual
    bool    there_are_superfluous_containers_in
        ( T_containers  const   &   containers )                                    const
    {
        return  false;
    }
    //-----------------------------------------------------------------------------------
    virtual
    int     weight()                                                                const
    {
        return  main_containers().size();
    }
    //-----------------------------------------------------------------------------------
    virtual
    bool    there_are_suitable_containers_to_choose_from_in
        ( T_containers   const   &   containers )                                   const
    {
        return      there_are_suitable_containers_in            ( containers )
                &&  is_not_subset_of_containers_of_any_answer   ( containers );
    }
    //-----------------------------------------------------------------------------------
private:
    //-----------------------------------------------------------------------------------
    virtual
    T_containers    main_containers()                                               const
    {
        return  std::accumulate
            (
                containers_of_answer_.begin     (),
                containers_of_answer_.end       (),
                T_containers                    (),
 
                [&] (
                        T_containers                        const   &   res_containers,
                        T_containers_of_answer::value_type  const   &   answer_and_containers
                    )
                {
                    return      res_containers
                            +   answer_and_containers.second;
                }
            );
    }
    //-----------------------------------------------------------------------------------
    virtual
    T_str   get_text_of_question_and_answer_with_num( int  answer_num )             const
    {
        auto    answer_and_containers_it    =   containers_of_answer_.begin();
 
        std::advance
            (
                answer_and_containers_it,
                answer_num - 1
            );
 
        return      "\n"
                +   question_text()
                +   "\t"
                +   answer_and_containers_it->first;
    }
    //-----------------------------------------------------------------------------------
    virtual
    void    modify_selected_containers_for_answer_num
        (
            T_containers    &   containers,
            T_answer_num        answer_num
        )                                                                           const
    {
        auto    answer_and_containers_it    =   containers_of_answer_.begin();
 
        std::advance
            (
                answer_and_containers_it,
                answer_num - 1
            );
 
        auto    answer_containers   =   answer_and_containers_it->second;
        containers  *=  answer_containers;
    }
    //-----------------------------------------------------------------------------------
    bool    is_not_subset_of_containers_of_any_answer
        ( T_containers   const   &   containers )                                   const
    {
        return      std::find_if
                        (
                            containers_of_answer_.begin     (),
                            containers_of_answer_.end       (),
 
                            [&]     (
                                        T_containers_of_answer::value_type  const   &   answer_and_containers
                                    )
                                    ->  bool
                            {
                                return  is_subset_of
                                            (
                                                containers,
                                                answer_and_containers.second
                                            );
                            }
                        )
 
                ==  containers_of_answer_.end();
    }
    //-----------------------------------------------------------------------------------
    virtual
    void    for_containers_set_numbers_and_texts_of_not_empty_answers
        (
            T_containers    const   &   containers,
            T_numbers               &   numbers,
            T_str                   &   answers_texts
        )                                                                           const
 
    {
        int     answer_num  =   0;
 
        std::for_each
            (
                containers_of_answer_.begin     (),
                containers_of_answer_.end       (),
 
                [&] ( T_containers_of_answer::value_type    const   &   answer_and_containers )
                {
                    ++answer_num;
 
                    if  (
                            !   (
                                        answer_and_containers.second
                                    *   containers
                                )
                                .empty()
                        )
                    {
                        numbers.insert( answer_num );
 
                        answers_texts.append
                            (
1
Эксперт С++
 Аватар для Mr.X
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
27.07.2015, 11:00
Часть 4
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
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
                                "\t"    +   answer_and_containers.first     +   "\n"
                            );
                    }//if
                }//lambda
            );
    }
    //-----------------------------------------------------------------------------------
};
/////////////////////////////////////////////////////////////////////////////////////////
class   T_containers_selector
{
    //-----------------------------------------------------------------------------------
    T_containers_data   containers_data_;
    T_containers        selected_containers_;
    T_str               value_type_name_;
    T_question_ptrs     question_ptrs_;
    T_str               answers_history_;
    //-----------------------------------------------------------------------------------
public:
    //-----------------------------------------------------------------------------------
    T_containers_selector()
        :
        selected_containers_( containers_data_.all_containers_ )
    {
        check_value_type();
        //===============================================================================
        //1
        question_ptrs_.insert
            (
                new     T_yes_or_not_question   (
                                                    "Нужен стек, или очередь, или очередь с приоритетами?",
                                                    containers_data_.all_containers_,
                                                    containers_data_.adapters_,
                                                    T_yes_question::ADAPTERS_QUESTION_WEIGHT
                                                )
            );
        //===============================================================================
        //2
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question  (
                                                            "Порядок последним пришел - первым ушел?",
                                                            containers_data_.all_containers_,
                                                                T_containers()
                                                            +   STACK
                                                        )
            );
        //===============================================================================
        //3
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question  (
                                                            "Порядок первым пришел - первым ушел?",
                                                            containers_data_.all_containers_,
                                                                T_containers()
                                                            +   QUEUE
                                                        )
            );
        //===============================================================================
        //4
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question  (
                                                            "Максимальный (минимальный) элемент уходит первым?",
                                                            containers_data_.all_containers_,
                                                                T_containers()
                                                            +   PRIORITY_QUEUE
                                                        )
            );
        //===============================================================================
        //5
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question  (
                                                            "Надо искать элементы по ключу?",
                                                            containers_data_.all_containers_,
                                                            containers_data_.key_containers_
                                                        )
            );
        //===============================================================================
        //6
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question  (
                                                            "Элементы отсортированы по ключу?",
                                                            containers_data_.all_containers_,
                                                            containers_data_.tree_containers_
                                                        )
            );
        //===============================================================================
        //7
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question  (
                                                            "Частые вставки или удаления в середине?",
                                                            containers_data_.all_containers_,
                                                            containers_data_.lists_containers_
                                                        )
            );
        //===============================================================================
        //8
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question  (
                                                            "Нужно производить упорядоченные выборки?",
                                                            containers_data_.all_containers_,
                                                            containers_data_.tree_containers_
                                                        )
            );
        //===============================================================================
        //9
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question  (
                                                            "Частые вставки или удаления в начале?",
                                                            containers_data_.all_containers_,
                                                            containers_data_.lists_and_deque_containers_
                                                        )
            );
        //===============================================================================
        //10
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question  (
                                                            "Надо быстро получить N-й элемент?",
                                                            containers_data_.all_containers_,
                                                            containers_data_.arrays_containers_
                                                        )
            );
        //===============================================================================
        //11
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question  (
                                                            "Дубликаты недопустимы?",
                                                            containers_data_.key_containers_,
                                                            containers_data_.not_multi_key_containers_
                                                        )
            );
        //===============================================================================
        //12
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question  (
                                                            "Нужно часто объединять большие контейнеры?",
                                                            containers_data_.all_containers_,
                                                            containers_data_.lists_containers_
                                                        )
            );
        //===============================================================================
        //13
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question  (
                                                            "Размер будет сильно меняться?",
                                                            containers_data_.all_containers_,
                                                                T_containers()
                                                            +   DEQUE
                                                        )
            );
        //===============================================================================
        //14
        question_ptrs_.insert
            (
                new     T_yes_or_not_question   (
                                                    "Хранить вместе ключ и значение?",
                                                    containers_data_.key_containers_,
                                                    containers_data_.sets_containers_
                                                )
            );
        //===============================================================================
        //15
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question  (
                                                            "Не нужно итерировать из конца в начало?",
                                                            containers_data_.lists_containers_,
                                                                T_containers()
                                                            +   FORWARD_LIST
                                                        )
            );
        //===============================================================================
        //16
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question  (
                                                            "Размер контейнера константный?",
                                                            containers_data_.all_containers_,
                                                                T_containers()
                                                            +   ARRAY
                                                        )
            );
        //===============================================================================
        //17
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question
                            (
                                "Нужна валидность всех итераторов после удаления элемента?",
                                containers_data_.all_containers_,
                                containers_data_.lists_and_hash_containers_
                            )
            );
        //===============================================================================
        //18
        question_ptrs_.insert
            (
                new     T_switch_question
                            (
                                "Временная сложность вставки в начало:",
                                "1) постоянная"        ,    containers_data_.lists_and_deque_and_hash_containers_,
                                "2) log N"             ,    containers_data_.tree_containers_,
                                "3) N"                 ,    containers_data_.vector_and_string_containers_,
                                "4) вообще невозможно" ,    containers_data_.array_containers_
                            )
            );
        //===============================================================================
        //19
        question_ptrs_.insert
            (
                new     T_switch_question
                            (
                                "Временная сложность вставки в середину:",
                                "1) постоянная"        ,    containers_data_.lists_and_hash_containers_,
                                "2) log N"             ,    containers_data_.tree_containers_,
                                "3) N"                 ,    containers_data_.vector_deque_string_containers_,
                                "4) вообще невозможно" ,    containers_data_.array_containers_
                            )
            );
        //===============================================================================
        //20
        question_ptrs_.insert
            (
                new     T_switch_question   (
                                                "Временная сложность поиска по значению:",
                                                "1) постоянная"     ,   containers_data_.hash_containers_,
                                                "2) log N"          ,   containers_data_.tree_containers_,
                                                "3) N"              ,   containers_data_.not_key_containers_
                                            )
            );
        //===============================================================================
        //21
1
Эксперт С++
 Аватар для Mr.X
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
27.07.2015, 11:00
Часть 5
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
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
        question_ptrs_.insert
            (
                new     T_switch_question   (
                                                "Временная сложность поиска N-го элемента:",
                                                "1) постоянная",    containers_data_.arrays_containers_,
                                                "2) N"         ,    containers_data_.lists_and_key_containers_
                                            )
            );
        //===============================================================================
        //22
        question_ptrs_.insert
            (
                new     T_switch_question
                            (
                                "Число указателей на один элемент контейнера:",
                                "1) 0",     containers_data_.array_and_vector_and_string_containers_,
                                "2) 1",     containers_data_.forward_list_and_deque_and_hash_containers_,
                                "3) 2",     containers_data_.not_forward_list_containers_,
                                "4) 3",     containers_data_.tree_containers_
                            )
            );
        //===============================================================================
        //23
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question
                            (
                                "Необходимо вставлять элементы в произвольное место контейнера?",
                                containers_data_.all_containers_,
                                    containers_data_.not_key_containers_
                                -   ARRAY
                            )
            );
        //===============================================================================
        //24
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question
                            (
                                "Надо искать элементы по ключу, не имея для него критерия сортировки?",
                                containers_data_.all_containers_,
                                containers_data_.hash_containers_
                            )
            );
        //===============================================================================
        //25
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question
                            (
                                "Нужен быстрый бинарный поиск в большом контейнере, не перемежающийся\n"
                                "вставкой и удалением элементов?",
                                containers_data_.all_containers_,
                                    T_containers()
                                +   VECTOR,
                                T_yes_question::QUICK_BINARY_SEARCH_QUESTION_WEIGHT
                            )
            );
        //===============================================================================
        //26
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question
                            (
                                "Элементы контейнера имеют высокую стоимость копирования/присваивания?",
                                containers_data_.all_containers_,
                                containers_data_.not_arrays_containers_
                            )
            );
        //===============================================================================
        //27
        question_ptrs_.insert
            (
                new     T_yes_or_not_relevant_question  (
                                                            "Нужен быстрый линейный поиск в большом контейнере?",
                                                            containers_data_.all_containers_,
                                                            containers_data_.arrays_containers_
                                                        )
            );
        //===============================================================================
        //28
        question_ptrs_.insert
            (
                new     T_switch_question
                            (
                                "Нужны быстрые случайные вставки/удаления:",
                                "1) маленьких элементов"    ,   containers_data_.vector_and_string_containers_,
                                "2) больших элементов"      ,   containers_data_.lists_containers_
                            )
            );
        //===============================================================================
    }
    //-----------------------------------------------------------------------------------
    void    select_container()
    {
        do
        {
            for (
                    size_t
                    i   =   0;
                    i   <   question_ptrs_.size();
                )
            {
                auto    question_ptr_it     =   question_ptrs_.begin();
 
                std::advance
                    (
                        question_ptr_it,
                        i
                    );
 
                if  (
                        ( *question_ptr_it )->there_are_superfluous_containers_in( selected_containers_ )
                    )
                {
                    ++i;
                    continue;
                }
 
                auto    question_is_relevant
                    =   ( *question_ptr_it )->there_are_suitable_containers_to_choose_from_in( selected_containers_ );
 
                if  (
                            !question_is_relevant
                        ||  ( *question_ptr_it )
                                ->successfully_ask_question_and_set_selected_containers_and_write_to_answers_history
                                (
                                    selected_containers_,
                                    answers_history_
                                )
                    )
                {
                    question_ptrs_.erase( question_ptr_it );
                }
                else
                {
                    ++i;
                }
 
                if( question_is_relevant )
                {
                    print_containers();
                }
 
                if  (
                        selected_containers_.size()  <=  1
                    )
                {
                    break;
                }
            }//for
        }
        while   (
                        question_ptrs_.size         ()  >   0
                    &&  selected_containers_.size   ()  >   1
                    &&  reply_to_question_is_yes    ( "Продолжить выбор контейнера?" )
                );
 
        std::cout   <<  "Выбор контейнера окончен."
                    <<  std::endl
 
                    <<  (
                            answers_history_.empty()
                                ?   "Контейнер не выбран."
                                :       "Контейнер выбран по следующим критериям:\n"
                                    +   answers_history_
                                    +   "."
                        )
 
                    <<  std::endl;
    }
    //-----------------------------------------------------------------------------------
private:
    //-----------------------------------------------------------------------------------
    void    check_value_type()
    {
        value_type_name_     =   reply_to_question_is_yes( "Тип элементов встроенный?" )
                                    ?   reply_to_question_is_yes( "Тип элементов char?" )
                                            ?   TYPE_NAME_CHAR
                                            :   reply_to_question_is_yes( "Тип элементов bool?" )
                                                    ?   TYPE_NAME_BOOL
                                                    :   TYPE_NAME_BUILT_IN
                                    :   USER_DEFINED_TYPE;
 
        if  (
                    value_type_name_
                !=  TYPE_NAME_CHAR
            )
        {
            selected_containers_.erase( STRING );
        }
    }
    //-----------------------------------------------------------------------------------
    static
    bool    reply_to_question_is_yes( T_str     const   &   question_text )
    {
        std::cout   <<  question_text
                    <<  " (y/n): ";
 
        T_str   s;
        std::cin    >>  s;
 
        return      std::tolower    (
                                        s.front()
                                    )
 
                ==  'y';
    }
    //-----------------------------------------------------------------------------------
    void    print_containers()                                                      const
    {
        std::cout   <<  "Тип элемента "
                    <<  value_type_name_
                    <<  "."
                    <<  std::endl;
 
        if  (
                selected_containers_.empty()
            )
        {
            std::cout   <<  "Таких контейнеров нет."
                        <<  std::endl;
        }
 
        std::for_each
            (
                selected_containers_.begin  (),
                selected_containers_.end    (),
 
                [&]                     ( T_container   container )
                {
                    std::cout   <<  get_container_name( container )
                                <<  std::endl;
                }
            );
 
        std::cout   <<  std::endl;
    }
    //-----------------------------------------------------------------------------------
    T_str   get_container_name( T_container   container )                           const
    {
        switch( container )
        {
        case    FORWARD_LIST        :   return  "forward_list";
        case    LIST                :   return  "list";
        case    ARRAY               :   return  "array";
 
        case    VECTOR              :   return  value_type_name_     ==  TYPE_NAME_BOOL
                                                    ?   "вместо vector<bool> рекомендуется использовать bitset или deque<bool>."
                                                    :   "vector";
 
        case    DEQUE               :   return  "deque";
        case    UNORDERED_MAP       :   return  "unordered_map";
 
        case    UNORDERED_SET       :   return  "unordered_set";
        case    UNORDERED_MULTIMAP  :   return  "unordered_multimap";
        case    UNORDERED_MULTISET  :   return  "unordered_multiset";
 
        case    SET                 :   return  "set";
        case    MAP                 :   return  "map";
        case    MULTISET            :   return  "multiset";
 
        case    MULTIMAP            :   return  "multimap";
        case    STACK               :   return  "stack";
        case    QUEUE               :   return  "queue";
 
        case    PRIORITY_QUEUE      :   return  "priority_queue";
        case    STRING              :   return  "string";
        default                     :   return  "";
        }//switch
    }
    //-----------------------------------------------------------------------------------
};
/////////////////////////////////////////////////////////////////////////////////////////
int     main()
{
    std::locale::global(std::locale(""));
    T_containers_selector  containers_selector;
    containers_selector.select_container();
    system("pause");
}
1
:)
Эксперт С++
4773 / 3267 / 497
Регистрация: 19.02.2013
Сообщений: 9,046
27.07.2015, 11:30
Цитата Сообщение от Mr.X Посмотреть сообщение
С детства блок-схемы не люблю. Моя программа для выбора контейнера:
Лучше наглядная и компактная блок-схема, чем прога, растянутая на 5 сообщений. Зачем так?
0
Эксперт С++
 Аватар для Mr.X
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
27.07.2015, 13:36
Цитата Сообщение от Tulosba Посмотреть сообщение
Лучше наглядная и компактная блок-схема, чем прога, растянутая на 5 сообщений.
Ну, программа немножко другой алгоритм реализует. Кстати, она очень наглядна в части списка вопросов (мне кажется, гораздо нагляднее запутанной блок-схемы), и в нее легко добавлять новые вопросы.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.07.2015, 13:36
Помогаю со студенческими работами здесь

Какой STL-контейнер выбрать?
Приветствую! Мне нужно выбрать STL-контейнер (C++11), для хранения элементов по ключу. Типа ключа - std::string, элемент - указатель...

Какой контейнер использовать в качестве рюкзака для персонажа в игре?
Всем добрый день, посоветуйте как лучше решить проблему: пишу консольную рпг, задумал сделать рюкзак персонажу в котором он будет хранить...

Какой контейнер можно использовать для быстрого сравнения 44-битовых хэшей?
Добрый день. Народ какой контейнер можно использовать для быстрого сравнения 44'битовых хэшов? хэшов примерно 5000000 QMap медленно...

Какой контейнер использовать?
Привет всем. Я только начинаю программировать на Си и поэтому со многими особенностями языка не знаком. К сожалению сейчас у меня слишком...

Какой контейнер использовать?
Всем привет! Нужно повторить след: Немного не пойму, какой контейнер нужно выбрать. ListView и изменить свой адаптер? Или GridView, но...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
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