Форум программистов, компьютерный форум, киберфорум
Visual C++
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 23.10.2020
Сообщений: 8

Проблемы с оптимизацией программы

23.10.2020, 18:38. Показов 717. Ответов 4

Студворк — интернет-сервис помощи студентам
Вот сам код:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <iostream>
using namespace std;
 
 
int main() {
    long long x, y, s = 0, max = 0, i1 = 0;
    int r;
    cin >> r;
    for (int i = 1; i <= r; ++i) {
        s = 0;
        for (x = -i - 1; x <= i; ++x)
            for (y = -i - 1; y <= i; ++y)
                if (x*x + y * y == i * i) ++s;
        if (max < s) { max = s;  i1 = i; }
    }
    cout << i1;
    return 0;
}
При попытке сдать задачу выдает TL, можно ли как-то ускорить код, заменить циклы for или сократить их количество?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
23.10.2020, 18:38
Ответы с готовыми решениями:

Проблемы с оптимизацией
Добавил на страницу ключевых слов, итог в Яше по этому запросу был на 60, вылез на 26. А в Гоше был на 105, сейчас на 130. Как быть?...

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

Перебор с оптимизацией? Не? :)
Здравствуйте! Использую такое внедрение: message('success', 'Вы авторизованы', 'auth', '/content/c-' . $auth = $_SESSION ?? null...

4
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
23.10.2020, 19:37
Цитата Сообщение от DiBrain Посмотреть сообщение
При попытке сдать задачу выдает TL, можно ли как-то ускорить код, заменить циклы for или сократить их количество?
Цитата Сообщение от DiBrain Посмотреть сообщение
if (x*x + y * y == i * i) ++s;
Здесь вычисление x * x и i *i можно вынести за цикл

Добавлено через 4 минуты
Не знаю, что ты тут пытаешься сделать, но ощущение, что это уравнение можно решить без циклов
0
0 / 0 / 0
Регистрация: 23.10.2020
Сообщений: 8
23.10.2020, 19:54  [ТС]
- вот само условие задачи
0
0 / 0 / 0
Регистрация: 23.10.2020
Сообщений: 8
23.10.2020, 22:11  [ТС]
oleg-m1973, как вариант мне предложили еще либо убрать перебор по i, либо брать map, проходить по всем x и y, вычислять r = √(x^2 + y^2), если число целое - увеличивать счётчик в map[r] и потом из всех map[r] выбирать r с наибольшим счётчиком. Но я не умею обращаться с map и итоговый код даже близко не похож на правильную оптимизацию... Возможно, могли бы помочь с кодом?
0
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
24.10.2020, 11:43
Цитата Сообщение от DiBrain Посмотреть сообщение
Но я не умею обращаться с map и итоговый код даже близко не похож на правильную оптимизацию... Возможно, могли бы помочь с кодом?
Ещё одно - у тебя там квадраты чисел, поэтому отрицательные значения можно, наверное, не перебирать
Что-то типа
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
for (int i = 1; i <= r; ++i) 
{
    s = 0;
    const int ii = i * i;
    for (x = 1; x <= i; ++x)
    {
        const int xx = x * x;
        for (y = 1; y <= i; ++y)
            if (xx + y * y == ii) 
                s += 2;
    }
    if (max < s) { max = s;  i1 = i; }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.10.2020, 11:43
Помогаю со студенческими работами здесь

Помогите с оптимизацией
Подскажи плиз с сайтом _www.atis-ars.ru. Сейчас сайт по словосочитанию &quot;охрана труда&quot; находится на 10 месте в яндексе, что надо...

Посоветуйте с оптимизацией
Занимаюсь оптимизацей гдет 1,5 года, хочу посоаветоваться емет ли смысл продвигать сайт не используя Ссылочное Ранжирование, а просто...

Помогите с оптимизацией
Написал вручную index.php, очень нужна оценка и какие-нить советы. Заранее спасибо! Файл вложил)

прблемы с оптимизацией
пишу на вижуал с 2008... проблема вот в чем - пока компилирую код просто так - вс пркрасно. стоит мне в свойствах - оптимизация-...

Помогите с оптимизацией
Есть сайт pcinfoportal.net.ru Помогите прооптимизировать его под поисковики. Что надо еще сделать. Подскажите.


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[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 и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru