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

Оптимизация кода и классы

01.11.2018, 21:59. Показов 1500. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, имеется программа, если это можно так назвать. Я думаю, что реализация и код здесь явно хромают, но я решил брать и делать теми знаниями, которые имею. Помогите пожалуйста оптимизировать её, подскажите что можно иначе, более эффективно, реализовать и что я сделал лишнего. И подскажите как вывести void Print() в файл.
Буду очень благодарен за советы, правки в коде не так важны, я хочу понять как лучше сделать и сделать это сам. Программа отлично компилируется, её можно запустить и сразу понять для чего она, в принципе, нужна

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
#include <iostream>
#include <string>
#include <Windows.h>
#include <fstream>
 
using namespace std;
 
class Date {
public:
 
    char street[70];
    int house;
    int phone;
 
    void Print() {
        cout << "Улица: " << street << "\nНомер дома: " << house << "\nТелефон: +380" << phone << endl;
    }
};
 
int main()
{
    SetConsoleOutputCP(1251);
    SetConsoleCP(1251);
 
    string Areas[4];
 
    string area1 = "Соломянский";
    string area2 = "Деснянский";
    string area3 = "Печерский";
 
    Areas[1] = area1;
    Areas[2] = area2;
    Areas[3] = area3;
 
    cout << "1. Соломянский" << endl;
    cout << "2. Деснянский" << endl;
    cout << "3. Печерский" << endl;
 
    cout << "Введите номер района: ";
 
    int number;
    cin >> number;
 
    Date client;
 
    cout << "Введите название улицы: " << endl;
    cin >> client.street;
    cout << "Введите номер дома: " << endl;
    cin >> client.house;
    cout << "Введите номер телефона, начиная с 0: " << endl;
    cin >> client.phone;
 
    system("cls");
    cout << "Ваш запрос: " << endl;
    
    client.Print();
    cout << "Район: " << Areas[number] << endl;
 
    ofstream output("text.txt");
    output << "Район: " << Areas[number] << endl;
 
    /*ofstream output("text.txt", ios::app);
    output << client.Print() << endl;*/
 
 
    return 0;
}
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.11.2018, 21:59
Ответы с готовыми решениями:

Шаблонные классы и оптимизация
Насколько в С++ проработана оптимизация шаблоннов? Действительно ли на каждый инстант шаблона функции создается свою функция? Вот,...

Оптимизация кода
Нужно както упростить програму /* Дан массив а если в нем встречается такой элемент что а &lt;a то а элемент нужно удалить его из...

Оптимизация кода
Нужно очень сильно оптимизировать код, даже пусть с использованием потоков, если это возможно! Суть: формируется последовательность...

11
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
01.11.2018, 22:19
Цитата Сообщение от TM1596 Посмотреть сообщение
Помогите пожалуйста оптимизировать её
Медленно работает?
0
1394 / 1023 / 325
Регистрация: 28.07.2012
Сообщений: 2,813
01.11.2018, 22:26
Лучший ответ Сообщение было отмечено TM1596 как решение

Решение

Цитата Сообщение от TM1596 Посмотреть сообщение
char street[70];
Не вижу причин тут не использовать std::string, как во всем остальном коде.
Цитата Сообщение от TM1596 Посмотреть сообщение
void Print()
Вместо этого лучше перегрузить оператор вывода. Это позволит выводить данные куда угодно, а не только через cout.

Для массивов можно использовать std::vector. Строки 35-37 можно заменить на цикл по Areas. Вместо строчек 27-33 массив можно инициализировать прямо в строке 25 через фигурные скобки.
1
112 / 91 / 31
Регистрация: 24.10.2018
Сообщений: 336
01.11.2018, 22:36
Если не заморачиваться, то примерно так:
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
#include <iostream>
#include <fstream>
#include <windows.h>
 
using namespace std;
 
struct Date
{
    string street;
    int house;
    int phone;
};
 
ostream& operator<<(ostream& o, const Date& date)
{
    o << "Улица: " << date.street << "\nНомер дома: " << date.house <<
        "\nТелефон: +380" << date.phone << endl;
    return o;
}
 
int main()
{
    SetConsoleOutputCP(1251);
    SetConsoleCP(1251);
    const char* Areas[4] = {"", "Соломянский", "Деснянский", "Печерский"};
 
    for(int i = 1; i < 4; ++i)
        cout<<i<<". "<<Areas[i]<<endl;
 
    cout << "Введите номер района: ";
 
    int number;
    cin >> number;
 
    Date client;
 
    cout << "Введите название улицы: " << endl;
    cin >> client.street;
    cout << "Введите номер дома: " << endl;
    cin >> client.house;
    cout << "Введите номер телефона, начиная с 0: " << endl;
    cin >> client.phone;
 
    cout << "\n\nВаш запрос: " << endl << client << "Район: " << Areas[number] << endl;
 
    ofstream of("text.txt");
    of << "Ваш запрос: " << endl << client << "Район: " << Areas[number] << endl;
    of.close();
 
    return 0;
}
1
 Аватар для TM1596
2 / 2 / 0
Регистрация: 10.12.2016
Сообщений: 50
01.11.2018, 22:57  [ТС]
Произвел некие изменения. Спасибо вам огромное, но всё же моя позиция "только советы, нет коду" глуповата. Можно на примере показать перегрузку вывода? Ещё раз благодарю

Код:
Кликните здесь для просмотра всего текста
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
#include <string>
#include <Windows.h>
#include <fstream>
#include <vector>
 
using namespace std;
 
class Date {
public:
 
    string street;
    int house;
    int phone;
 
    void Print() {
        cout << "Улица: " << street << "\nНомер дома: " << house << "\nТелефон: +380" << phone << endl;
    }
};
 
int main()
{
    SetConsoleOutputCP(1251);
    SetConsoleCP(1251);
 
 
    vector <string> Areas(4);
    Areas[1] = "1. Соломянский";
    Areas[2] = "2. Деснянский";
    Areas[3] = "3. Печерский";
 
    for (int i = 1; i < 4; i++) {
        cout << Areas[i] << endl;
    }
 
    cout << "Введите номер района: ";
 
    int number;
    cin >> number;
 
    Date client;
 
    cout << "Введите название улицы: " << endl;
    cin >> client.street;
    cout << "Введите номер дома: " << endl;
    cin >> client.house;
    cout << "Введите номер телефона, начиная с 0: " << endl;
    cin >> client.phone;
 
    system("cls");
    cout << "Ваш запрос: " << endl;
    
    client.Print();
    cout << "Район: " << Areas[number] << endl;
 
    ofstream output("text.txt");
    output << "Район: " << Areas[number] << endl;
 
    /*ofstream output("text.txt", ios::app);
    output << client.Print() << endl;*/
 
 
    return 0;
}
0
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
01.11.2018, 22:59
Цитата Сообщение от TM1596 Посмотреть сообщение
Можно на примере показать перегрузку вывода?
В сообщении выше от krolligator посмотрите на строки 14-19. Это оно.
1
 Аватар для TM1596
2 / 2 / 0
Регистрация: 10.12.2016
Сообщений: 50
01.11.2018, 23:11  [ТС]
Компилятор не компилирует
А если серьёзно, то так и есть:
Кликните здесь для просмотра всего текста

Это же можно исправить?

Пожалуйста скиньте ссылку, глядя на опыт, на хороший материал по перегрузке ф-ции вывода и вообще ф-ций? Спасибо.
Ибо я смотрю на код krolligator 'а и он меня пугает.
0
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
01.11.2018, 23:13
Цитата Сообщение от TM1596 Посмотреть сообщение
Это же можно исправить?
Код покажите.
0
 Аватар для TM1596
2 / 2 / 0
Регистрация: 10.12.2016
Сообщений: 50
01.11.2018, 23:15  [ТС]
Это код от krolligator'а, он пока не изменился:
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
#include <iostream>
#include <fstream>
#include <Windows.h>
 
using namespace std;
 
struct Date
{
    string street;
    int house;
    int phone;
};
 
ostream& operator<<(ostream& o, const Date& date)
{
    o << "Улица: " << date.street << "\nНомер дома: " << date.house <<
        "\nТелефон: +380" << date.phone << endl;
    return o;
}
 
int main()
{
    SetConsoleOutputCP(1251);
    SetConsoleCP(1251);
    const char* Areas[4] = { "", "Соломянский", "Деснянский", "Печерский" };
 
    for (int i = 1; i < 4; ++i)
        cout << i << ". " << Areas[i] << endl;
 
    cout << "Введите номер района: ";
 
    int number;
    cin >> number;
 
    Date client;
 
    cout << "Введите название улицы: " << endl;
    cin >> client.street;
    cout << "Введите номер дома: " << endl;
    cin >> client.house;
    cout << "Введите номер телефона, начиная с 0: " << endl;
    cin >> client.phone;
 
    cout << "\n\nВаш запрос: " << endl << client << "Район: " << Areas[number] << endl;
 
    ofstream of("text.txt");
    of << "Ваш запрос: " << endl << client << "Район: " << Areas[number] << endl;
    of.close();
 
    return 0;
}
0
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
01.11.2018, 23:18
Цитата Сообщение от TM1596 Посмотреть сообщение
Это код от krolligator'а, он пока не изменился:
#include <string>
1
 Аватар для TM1596
2 / 2 / 0
Регистрация: 10.12.2016
Сообщений: 50
01.11.2018, 23:24  [ТС]
Спасибо, внимательность тоже, наверное, приходит с опытом.
0
02.11.2018, 10:37

Не по теме:

Хех, самую первую строчку пропустил при копировании кода :)

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.11.2018, 10:37
Помогаю со студенческими работами здесь

Оптимизация кода
В общем дело такое, мне нужно 2 одинаковые программы(небольшие), только одна программа должна быть неоптимизированная, а другая, точно...

Оптимизация кода
if (sum % 10 == 1 || sum % 10 == 2 || sum % 10 == 3 || sum % 10 == 4) Можно ли как-то оптимизировать данную &quot;строку&quot;? За...

Оптимизация кода
main: #include &lt;iostream&gt; #include &lt;conio.h&gt; #include &quot;keyBuffer.h&quot; #include &quot;pause.h&quot; #include &lt;windows.h&gt; const char...

Оптимизация кода
Доброго времени сутки господа у меня к вам вопрос как можно оптимызуваты данный код? #include &lt;stdio.h&gt; #include &lt;stdlib.h&gt;...

Оптимизация кода
Как можно оптимизировать данный программный код? Ответ объяснить void func() { for (int i = 0; i &lt; len; i++) { ...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru