Найти максимум числового выражения25.09.2016, 14:03. Показов 1614. Ответов 33
Метки нет (Все метки)
Задано числовое выражение
(sin1 + ... + sin(k)) * (sin(k+1) + ... + sin(n)) в двух скобках проставлены суммы синусов от чисел натурального ряда. Всего чисел 100 и они расположены в порядке возрастания от 1 до 100. Однако сколько этих чисел в каждой скобке неизвестно. может 1, а может 99 Надо вычислить максимум независимо от N. 1 < N <=100 Вопросы 1. Есть ли иное решение? 2. Можно ли улучшить мою программу? 3. Кажется здесь можно использовать рекурсию? например по количеству синусов во второй скобке?
0
|
||||||
| 25.09.2016, 14:03 | |
|
Ответы с готовыми решениями:
33
|
|
Супер-модератор
|
||
| 26.09.2016, 11:29 | ||
граничных случаях, потому что программист уверен, что "этого не может быть, потому что не может быть никогда" (С) А потом ракеты падают, и самолеты крушатся. И люди погибают. А программист, блин, сидя в теплом кресле, и попивая кофе, опять уверен, что такого не может быть, и опять пишет по прежнему.
1
|
||
|
Платежеспособный зверь
8966 / 4389 / 1655
Регистрация: 28.10.2009
Сообщений: 11,647
|
||
| 26.09.2016, 12:01 | ||
|
Вот Вам пример: sin(1)+sin(2)+sin(3)>0 sin(4)<0 произведение отрицательно... Всяко бывает в жизни...
0
|
||
| 26.09.2016, 12:47 | ||
|
Например, в олимпиадных задачах есть ограничение на количество используемой памяти (как правило несколько мегабайт) и ограничение по времени, сколько программа тратит на решение (несколько секунд). Поэтому реализация быстрого алгоритма более приоритетно. Все зависит от задачи, я уже писал, что нужно находить баланс между объемом используемой памяти и временем вычисления.
0
|
||
| 26.09.2016, 12:50 [ТС] | |
|
Глубоко уважаемый кот Бегемот,
вы привели пример того, что (sin(1)+sin(2)+sin(3)) * (sin(4)) < 0. Да! Это верно! Но верно также и другое (sin1) * (sin2) > 0 А в максимум ваше выражение не пойдет, ведь есть и большие числа. Мой пример тоже не пойдет - есть еще большие... примечание видимо в этом и состоит сложность задачи...
0
|
|
|
Платежеспособный зверь
8966 / 4389 / 1655
Регистрация: 28.10.2009
Сообщений: 11,647
|
||||
| 26.09.2016, 13:34 | ||||
|
а справедливость этого выражения Добавлено через 5 минут
0
|
||||
| 26.09.2016, 13:44 | |
|
А нужно доказывать выражение?
sin(a)*sin(b) >= -1 Добавлено через 9 минут кот Бегемот, я привел два варианта программы с массивом и без, принципиально алгоритм не отличается от Вашего, просто убрал лишние вычисления, либо заменил их на более быстрые. Если Вы не ставите перед собой задачи написать более менее оптимальный код, то не буду Вас в этом переубеждать.
0
|
|
|
Платежеспособный зверь
8966 / 4389 / 1655
Регистрация: 28.10.2009
Сообщений: 11,647
|
|||
| 26.09.2016, 15:32 | |||
|
Совершенно с Вами согласен, речь шла исключительно о массивах
0
|
|||
| 26.09.2016, 16:13 | |||
|
при n=2, k может быть равен только 1, соответственно имеем только один вариант sin(1)*sin(2), и значение этого выражения не менее -1 при n=100, k изменяется от 1 до 99, получаем значения: от (sin1)*(sin2+sin3+...+sin99+sin100) до (sin1+sin2+...sin98+sin99)*sin100, значение которых не может быть меньше -99 (1*-99 или -1*99)
0
|
|||
|
Платежеспособный зверь
8966 / 4389 / 1655
Регистрация: 28.10.2009
Сообщений: 11,647
|
||
| 26.09.2016, 21:09 | ||
|
В моей программе команда max=-100 и показывает, что меньше -100 быть не может.
0
|
||
|
Заблокирован
|
|
| 26.09.2016, 21:30 | |
|
0
|
|
| 26.09.2016, 21:39 | ||
|
Вы спрашивали, "почему -1?" я ответил на этот вопрос, даже логично было бы написать -99, но -100 откуда берется? по условию задачи не может быт суммы в 100 синусов, максимум - 99
0
|
||
|
Платежеспособный зверь
8966 / 4389 / 1655
Регистрация: 28.10.2009
Сообщений: 11,647
|
|
| 26.09.2016, 23:19 | |
|
Сказать честно, Ваши последние фразы очень сильно портят впечатление о вашем интеллекте. Мне казалось очевидным, что в качестве начального (минимального) значения для max надо выбрать число, заведомо меньшее любого возможного max. Очевидно, что минимальная сумма 100 синусов=-100. Вот и всё.
0
|
|
| 27.09.2016, 06:52 | |||
|
Можете говорить сколько угодно про очевидность присвоения -100 (так мне очевидно что и -1 и -99 подходят для этого, а можно и с запасом задать -9E+307), только потом будим слушать лекции от volvo про падающие ракеты и самолеты.
0
|
|||
| 27.09.2016, 06:52 | |
|
Помогаю со студенческими работами здесь
34
Найти минимум и максимум в массивах чисел и вычислить значение выражения Найти максимум в диагонали матрицы и перевернуть строки, в которых есть этот максимум Разбор числового выражения Вычислить значение числового выражения Найти максимум из девяти чисел(максимум из трех чисел(максимум из двух чисел) Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога
Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
|
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога
Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
|
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога
Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
|
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
|
|
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога
В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
|
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога
Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
|
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
|