Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
 Аватар для VLaDoS_2001a
319 / 216 / 114
Регистрация: 14.05.2020
Сообщений: 890

Оптимизировать работу программы

25.07.2020, 23:26. Показов 1230. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
60/100%
https://www.e-olymp.com/ru/con... ems/172502
Написал код для решения задачи 4853, но с памятью беда как можно исправить?
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
#include <iostream>
#include <vector>
#include <queue>
using namespace std;
 
int main(void)
{
    ios_base::sync_with_stdio(false);
    cin.tie(nullptr);
    int n,m,a,b,x,y;
    cin >> n >> m >> a >> b;
    vector<vector<int>>arr(n+1,vector<int>(n+1,0));
    vector<vector<int>>brr(n+1);
        for(size_t  i = 1; i<= m; ++i)
        {
          cin>>x>>y;
          arr[x][y] = arr[y][x] = 1;
        }
    
    for(size_t j, i = 1; i <= n; ++i)
    {
        for(j = 1; j<= n; ++j)
        {
         if(arr[i][j] == 1) brr[i].emplace_back(j);
        }
    }
    vector<int>d(n+1,-1);
    vector<int>prev(n+1,-1);
    d[a] = 0;
    queue<int>q;
    q.push(a);
    
    int curr;
    while(!q.empty())
    {
        curr = q.front();
        q.pop();
        for(auto&i:brr[curr])
        {
            if(d[i] == -1)
            {
                d[i] = d[curr] + 1;
                q.push(i);
                prev[i] = curr;
            }
        }
    }
    cout<<d[b]<<endl;
    vector <int> ans; ans.reserve(256);
curr = b;
 while (curr != -1)
{
    ans.emplace_back(curr);
    curr = prev[curr];
}
for(size_t i = 0; i < ans.size(); ++i)
{
    cout<<ans[ans.size()-i-1]<<" ";
}
    
    return 0;
}
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.07.2020, 23:26
Ответы с готовыми решениями:

Вывести все правильные скобочные выражения (оптимизировать алгоритм, ускорить работу кода)
есть код, нужно cout и cin перевести на printf и scanf дополнительных библиотек не подключать! проблема в том что при вводе 14 работает...

Оптимизировать скорость выполнения программы
написал простенькую программку но для часиков до 1мин загрузки это черезчур,вот код: #include &lt;vcl.h&gt; #pragma hdrstop ...

Как оптимизировать работу программы визуализации графов?
В общем, программа должна генерировать граф и визуализировать его, всё работает, но если вводить число вершин больше 30, то генерируется и...

2
Just Do It!
 Аватар для XLAT
4211 / 2669 / 655
Регистрация: 23.09.2014
Сообщений: 9,083
Записей в блоге: 3
26.07.2020, 00:25
Лучший ответ Сообщение было отмечено VLaDoS_2001a как решение

Решение

Цитата Сообщение от VLaDoS_2001a Посмотреть сообщение
как можно исправить?
выкиньте матрицу смежности

Цитата Сообщение от VLaDoS_2001a Посмотреть сообщение
vector<vector<int>>arr(n+1,vector<int>(n +1,0));
50000 * 50000 * 4 ~ 10 Gb памяти под вашу матрицу!
0
 Аватар для VLaDoS_2001a
319 / 216 / 114
Регистрация: 14.05.2020
Сообщений: 890
26.07.2020, 00:56  [ТС]
XLAT, Большое спасибо!

Добавлено через 29 секунд
100%/100%
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
#include <iostream>
#include <vector>
#include <queue>
using namespace std;
int main(void)
{
    ios_base::sync_with_stdio(false);
    cin.tie(nullptr);
    int n,m,a,b,x,y,tmp;
    cin>>n>>m>>a>>b;
    vector<vector<int>>arr(n+1);
    for(size_t i = 0; i < m; ++i)
    {
        cin>>x>>y;
        arr[x].emplace_back(y);
        arr[y].emplace_back(x);
    }
    vector<int>d(n+1,-1);
    vector<int>prev(n+1,-1);
    queue<int>q;
    d[a] = 0;
    q.push(a);
    while(!q.empty())
    {
        tmp=q.front();
        q.pop();
        
        for(auto&i:arr[tmp])
        {
            if(d[i]==-1)
            {
                d[i] = d[tmp] + 1;
                prev[i] = tmp;
                q.push(i);
            }
        }
    }
    cout<<d[b]<<endl;
    vector<int>ans;
    tmp=b;
    while(tmp!=-1)
    {
      ans.emplace_back(tmp);
      tmp=prev[tmp];
    }
    
    for(size_t i = 0; i <ans.size(); ++i)
    {
        cout<<ans[ans.size()-i-1]<<" ";
    }
    cout<<endl;
    return EXIT_SUCCESS;
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
26.07.2020, 00:56
Помогаю со студенческими работами здесь

Оптимизировать работу программы, собрав 4 функции в одну
нужно оптимизировать скрипт. написала 4 функции для соответствующих форм, которые делают одно и то же. наверное, нужно создать какой то...

Оптимизировать работу
Подскажите что необходимо менять в JS для того что бы получить мне нужный результат. Сейчас JS формирует 6 секторов с кнопками, на кнопках,...

Оптимизировать работу с диапазоном ячеек
Добрый день Всех с новым годом Есть макрос мне надо чтобы его использовать в диапазоне B2:B1000 не хочется каждый диапазон по...

Оптимизировать работу игрового клуба
:help: Доброго времени суток! Мне предстоит подключить 11 компьютеров. Задача такая: - работа компьютеров по сети - работа...

Как лучше оптимизировать работу с данными БД
Здравствуйте. У меня в приложении есть функция работы с адресами из Кладр. Выглядит это как на скриншоте. Первоначально я хотел по...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru