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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
ZoriZ
0 / 0 / 0
Регистрация: 11.07.2015
Сообщений: 2
#1

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

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

Какой контейнер в STL и для чего эффективнее использовать? И почему
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.07.2015, 17:38
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Какой контейнер в STL и для чего эффективнее использовать? (C++):

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

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

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

Когда какой контейнер использовать? - C++
Поделитесь опытом, когда и при каких условиях какой контейнер особенно удобен? Только поменьше абстракции пожалуйста :)

Прочитать массив чисел неизвестной длины. Какой контейнер использовать? - C++
Доброго времени суток! И всех с наступающими праздниками :drink: В общем необходимо считать последовательность чисел, заранее неизвестной...

Какую функцию STL использовать для работы с множеством ? - C++
Есть 2 множества : а и b for( int i = 0; i < 5; i++) { a.insert(i); } ...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Mr.X
Эксперт С++
3049 / 1694 / 265
Регистрация: 03.05.2010
Сообщений: 3,867
27.07.2015, 10:56 #16
Часть 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
Эксперт С++
3049 / 1694 / 265
Регистрация: 03.05.2010
Сообщений: 3,867
27.07.2015, 11:00 #17
Часть 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
Эксперт С++
3049 / 1694 / 265
Регистрация: 03.05.2010
Сообщений: 3,867
27.07.2015, 11:00 #18
Часть 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
Tulosba
:)
Эксперт С++
4396 / 3239 / 297
Регистрация: 19.02.2013
Сообщений: 9,045
27.07.2015, 11:30 #19
Цитата Сообщение от Mr.X Посмотреть сообщение
С детства блок-схемы не люблю. Моя программа для выбора контейнера:
Лучше наглядная и компактная блок-схема, чем прога, растянутая на 5 сообщений. Зачем так?
0
Mr.X
Эксперт С++
3049 / 1694 / 265
Регистрация: 03.05.2010
Сообщений: 3,867
27.07.2015, 13:36 #20
Цитата Сообщение от Tulosba Посмотреть сообщение
Лучше наглядная и компактная блок-схема, чем прога, растянутая на 5 сообщений.
Ну, программа немножко другой алгоритм реализует. Кстати, она очень наглядна в части списка вопросов (мне кажется, гораздо нагляднее запутанной блок-схемы), и в нее легко добавлять новые вопросы.
1
DrOffset
27.07.2015, 21:23
  #21
 Комментарий модератора 
Ребята. Давайте заканчивать выяснять отношения.
Дискуссия по стилю оформления кода Mr.X в этой теме неуместна.
0
dailydose
overmind
336 / 116 / 30
Регистрация: 21.07.2016
Сообщений: 572
05.01.2017, 10:16 #22
Цитата Сообщение от Mr.X Посмотреть сообщение
Моя программа для выбора контейнера:
Не могли бы Вы её выложить отдельным файлом или архивом?
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
05.01.2017, 10:16
Привет! Вот еще темы с ответами:

STL, контейнер set - C++
Помогите, пожалуйста. Задание состоит вот в чем: даны названия городов, и для них перечислены города, в которые можно попасть без...

Упорядочить список по возрастанию (для решения задачи использовать STL) - C++
Во входном файле в первой строке три слова и число (13 12 65) в последующих тоже самое. Проверьте код, пожалуйста, выводит непонятные...

STL контейнер ошибка компиляции - C++
#include &lt;iostream&gt; #include &lt;map&gt; #include &lt;iterator&gt; #include &lt;string&gt; using namespace std; int main() { string word; ...

C++ STL Создать контейнер (Stack) - C++
1. Создать объект-контейнер и заполнить его данными, тип stack 2. Просмотреть контейнер. 3. Изменить контейнер, удалив из него одни...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
05.01.2017, 10:16
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru