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

структурный шаблон

24.03.2022, 17:46. Показов 307. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Помогите дописать код.Перечень наборов конфет я сделал. Помогите пожалуйста с остальным. Не могу понять как дописать код с наименованием наибольшего по весу набора. Зарание большое спасибо!!!
Вот задание.
По забросу пользователя предусмотреть вывод следующих дан-
ных:
- перечень всех наборов конфет, отсортированных по возрастанию
стоимости;
- наименование наибольшего по весу набора;
- всю информацию о наборе, наименование которого вводится с кла-
виатуры;
- перечень наименований наборов, в состав которых входят конфеты
определенного наименования.
Код
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
#include<iostream>
#include<iomanip>
#include <string>
#include <windows.h>
#include <cctype>
using namespace std;
 
struct record{
    int num;        //номер записи
    string set;     // Наименование набора
    string name;    // Наименование конфет
    int weight;     // Вес набора          
    int price;      // Цена набора
};
 
void vvod (record *arr);
void inference (record *arr);
void sets (record *arr);
void max (record *arr);
 
int main()
{
    setlocale (LC_ALL, "Rus");
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    
    int SIZE;
    cout << "Введите количество элементов" << endl;
    cin >> SIZE;
    int n;
    
    record *arr = new record[SIZE];
    arr[0].num = 0;
    
    while (1){
    cout << "Выберите пункт:" << endl <<
    "0. Выход из программы" << endl << 
    "1. Ввод данных" << endl << 
    "2. Вывод данных" << endl << 
    "3. перечень всех наборов конфет, отсортированных по возрастанию стоимости" << endl <<
    "4. наименование наибольшего по весу набора" << endl <<
    "5. всю информацию о наборе, наименование которого вводится с клавиатуры" << endl << 
    "6. перечень наименований наборов, в состав которых входят конфеты определенного наименования" << endl; 
    
    cin >> n;
    while (n < 0 || n > 6 || cin.fail()){
        cin.clear();    //Возврат cin в обычный режим работы
        cin.ignore(1000, '\n');     //очищение предыдущего потока ввода
        cout << "Неправильные ввод!!!\n Введите номер пункта (от 0 до 6)\n";
        cin >> n;
    }   
        switch (n){
            case 0: cout << "Выход из программы" << endl;
            delete [] arr;
            return 0;
        break;  
            case 1: cout << "Ввод данных" << endl; 
            vvod(arr); 
        break;
            case 2: cout << "Вывод данных" << endl; inference (arr);
        break;
            case 3: cout << "перечень всех наборов конфет, отсортированных по возрастанию стоимости" << endl; sets (arr);
        break;
            case 4: cout << "наименование наибольшего по весу набора" << endl; max (arr);
        break;
            /*case 5: cout << "всю информацию о наборе, наименование которого вводится с клавиатуры" << endl; surname (arr);
        break;
            /*case 6: cout << "перечень наименований наборов, в состав которых входят конфеты определенного наименования" << endl; lecture (arr);
        break;*/
        }
    }
        
    delete [] arr;
    return 0;
}
 
 
 
void vvod(record *arr){
    int n = 0;
    int i = 1;
    while(arr[n].num){
        n++;
    }
    arr[n].num = n+1;
    arr[n+1].num = 0;
    
    cout << "Введите название набора:\n";
    cin.ignore(1000, '\n');
    getline(cin, arr[n].set);
    while(!arr[n].set.length()){ 
        cout << "Пустой ввод. Повторите:\n";
        cin >> arr[n].set;
    }
    
    cout << "Введите название конфет:\n";
    getline(cin, arr[n].name);
    
    while(!arr[n].name.length()){ 
        cout << "Пустой ввод. Повторите:\n";
        cin >> arr[n].name;
    }
    
    
    cout << "Введите вес:\n";
    cin >> arr[n].weight;                                       
    while(arr[n].weight < 0 || cin.fail()){ //cin.fail() - если предыдущее извлечение не выполнилось или произошло переполнение,
        //ВЫполняется кода введены не верные данные
        cin.clear();    //Возврат cin в обычный режим работы
        cin.ignore(1000, '\n');     //очищение предыдущего потока ввода
        cout << "Неправильные ввод!!!\nВведите вес\n";
        cin >> arr[n].weight;
    }
    
    cout << "Введите цену набора:\n";
    cin >> arr[n].price;                                        //
    while(arr[n].price < 0 || cin.fail()){ //cin.fail() - если предыдущее извлечение не выполнилось или произошло переполнение,
        //ВЫполняется кода введены не верные данные
        cin.clear();    //Возврат cin в обычный режим работы
        cin.ignore(1000, '\n');     //очищение предыдущего потока ввода
        cout << "Неправильные ввод!!!\nВведите цену\n";
        cin >> arr[n].price;
    }
    
    cout << "Prodoljit?" << endl;
    cin >> i;
    
    if (i == 1){
        vvod(arr);
    }   
}
    
void inference (record *arr){
    
    cout << "----------------------------------------------------------------------------------------------------------------------" << endl;
    cout << "| №  " << "|    Набор                " << "|         Название конфет           " << "|            Вес набора       "<< "   | Цена набора    |" << endl;
    cout << "----------------------------------------------------------------------------------------------------------------------" << endl;
    
    int i = 0;
        while(arr[i].num){
                                
        cout << "| " << setiosflags(ios::left)  << setw(3) << arr[i].num << "| " << setw(24) << arr[i].set << "|" << setw(35) <<  arr[i].name << "|" << setw(32) << arr[i].weight << "|" << setw(16) << arr[i].price << "|" << endl;
        cout << "----------------------------------------------------------------------------------------------------------------------" << endl;   
        i++; 
        }
}   
 
void sets (record *arr){ 
    
    int n = 0; // колличество заполненных элементов в массиве arr
    while (arr[n].num){
        n++;
    }
    
    record temp;
    for (int i = 0; i < n - 1; i++){
        for (int j = 0; j < n - 1; j++){
                    if (arr[j].price > arr[j+1].price){
                temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }   
    }
    
 
    
    inference (arr);
    
    delete [] arr;
    
}           
 
void max (record *arr){
    
    int n = 0; // колличество заполненных элементов в массиве arr
    while (arr[n].num){
        n++;
    }
    
    
    for (int i=0; i<n; i++){
        if (arr[i].weight > arr[i+1].weight){
            
        }
    }
 
    
    inference (arr);
    
    delete [] arr;
    
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.03.2022, 17:46
Ответы с готовыми решениями:

Создать структурный шаблон
Создал код для воспроизведения шаблона. При компиляции когда должен появляться шаблон программа начинает какой то цикл. Пожалуйста...

Структурный шаблон о коллекции книголюба
Моё задание звучит так: Структурный шаблон должен содержать сведения о коллекции книголюба: шифр книги, автор, название, год издания,...

Описать структурный шаблон для представления комплексного числа
Описать структурный шаблон для представления комплексного числа, содержащий поля: вещественная и мнимая часть. Написать програм-му,...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.03.2022, 17:46
Помогаю со студенческими работами здесь

Создать структурный шаблон, содержащий сведения о комплектации набора подарочных конфет
Создать структурный шаблон, содержащий сведения о комплектации набора подарочных конфет: название набора, массив наименований конфет,...

Создать структурный шаблон, хранящий сведения о комплектации, стоимости и количества компьютеров на складе
16. Создать структурный шаблон, хранящий сведения о комплектации, стоимости и количества компьютеров на складе магазина: модель, объем...

Переписать один структурный массив в другой структурный массив
Определить структурный тип, описывающий расписание полетов самолетов (пункт назначения, время отправления, время прибытия, время полета,...

Какой шаблон тут используется? Шаблон класса или шаблон функции
Какой шаблон тут используется? Шаблон класса или шаблон функции,и с объяснениями пожалуйста #include &lt;iostream&gt; using...

Структурный тип
Заданы две дроби (числитель и знаменатель – поля структуры). Напишите функции вычисления сложения, вычитания, умножения и деления дробей....


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Архитектурные паттерны микросервисов: ТОП-10 шаблонов
ArchitectMsa 22.03.2025
Популярность микросервисной архитектуры объясняется множеством важных преимуществ. К примеру, она позволяет командам разработчиков работать независимо друг от друга, используя различные технологии и. . .
Оптимизация рендеринга в Unity: Сортировка миллиона спрайтов
GameUnited 22.03.2025
Помните, когда наличие сотни спрайтов в игре приводило к существенному падению производительности? Время таких ограничений уходит в прошлое. Сегодня геймдев сталкивается с задачами совершенно иного. . .
Образование и практика
Igor3D 21.03.2025
Добрый день А вот каково качество/ эффективность ВУЗовского образования? Аналитическая геометрия изучается в первом семестре и считается довольно легким курсом, что вполне справедливо. Ну хорошо,. . .
Lazarus. Таблица с объединением ячеек.
Massaraksh7 21.03.2025
Понадобилась представление на экране таблицы с объединёнными ячейками. И не одной, а штук триста, и все разные. На Delphi я использовал для этих целей TStringGrid, и то, кривовато получалось. А в. . .
Async/await в Swift: Асинхронное программировани­е в iOS
mobDevWorks 20.03.2025
Асинхронное программирование долго было одной из самых сложных задач для разработчиков iOS. В течение многих лет мы сражались с замыканиями, диспетчеризацией очередей и обратными вызовами, чтобы. . .
Колмогоровская сложность: Приёмы упрощения кода
ArchitectMsa 20.03.2025
Наверное, каждый программист хотя бы раз сталкивался с кодом, который напоминает запутанный лабиринт — чем дальше в него погружаешься, тем сложнее найти выход. И когда мы говорим о сложности кода, мы. . .
PostgreSQL в Kubernetes: Подготовка кластера и настройка
Mr. Docker 20.03.2025
Когда доходит до контейнеризации баз данных и особенно таких требовательных к ресурсам системах как PostgreSQL, многие команды до сих пор колеблются, прежде чем перенести их в контейнерную. . .
C++26: Индексирование пакетов и метапрограммиро­вание
bytestream 20.03.2025
Эволюция C++ продолжается стремительными темпами – каждый новый стандарт приносит функциональность, о которой мы мечтали годами. Звучит слишком громко? Если вы когда-либо боролись с вариадическими. . .
Состояние гонки в C#: подводные камни многопоточного программировани­я
UnmanagedCoder 20.03.2025
Что такое состояние гонки? Это ситуация, когда результат программы непредсказуемо меняется в зависимости от порядка выполнения потоков. Проще говоря, два или более потока пытаются одновременно. . .
Next.js для разработки React: преимущества серверного рендеринга
Reangularity 20.03.2025
Next. js решает классическую проблему React-приложений: медленную первоначальную загрузку и плохую индексацию поисковиками. Вместо того чтобы заставлять браузер пользователя выполнять всю работу по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер