Форум программистов, компьютерный форум, киберфорум
Pascal ABC
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.97/34: Рейтинг темы: голосов - 34, средняя оценка - 4.97
0 / 0 / 0
Регистрация: 05.03.2017
Сообщений: 31

Колонизация Марса

08.03.2017, 12:35. Показов 7242. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Такая вот задача, на одном из сайтов ее предагают решить перебором через рекурсию, как реализовать я вообще не представляю, поясните пожалуйста
Имя входного файла: стандартный ввод или in.txt
Имя выходного файла: стандартный вывод или out.txt
Ограничение по времени: 2 секунды
Ограничение по памяти: 256 Мб
Ученым удалось отправить на планету Марс мини-фабрику, которая может за одни
сутки произвести мини-фабрику или дрона для сбора воды (мини-фабрика или дрон для сбора воды могут начать работу только со следующих суток). Дрон собирает одну единицу воды за одни сутки.
Определите, за какое минимальное количество суток удастся собрать не менее N единиц воды.
Формат входных данных
Задается одно число N (1 меньше или равно N меньше или равно 10^9) – необходимое количество воды.
Формат выходных данных
Одно целое число M – минимально необходимое количество суток.
Примеры:
стандартный ввод стандартный вывод
2 3
Замечание
Одна из правильных последовательностей действий выглядит так:
 В первые сутки мини-фабрика производит дрона для сбора воды;
 За вторые сутки мини-фабрика производит еще одного дрона, а первый дрон
собирает одну единицу воды;
 За третьи сутки мини-фабрика может произвести еще одного дрона или мини-
фабрику, при этом первый дрон собирает еще одну единицу воды (итого он собрал
2 единицы воды), а второй дрон собирает единицу воды. Таким образом, накоплено
3 единицы воды за трое суток.
Другая последовательность действий состоит в том, чтобы за первые сутки построить еще
одну мини-фабрику, а за вторые сутки произвести двух дронов, которые на третьи сутки
соберут 2 единицы воды.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.03.2017, 12:35
Ответы с готовыми решениями:

Для освоения Марса требуется построить исследовательскую базу
Здравствуйте, нужна помощь для решения двух олимпиадных задач по информатике, условия задач описаны ниже. Если кто-то сможет написать код,...

В Google появилась карта Марса
Компания Google предоставила интернет-пользователям возможность для изучения Марса. Карта красной планеты имеет несколько режимов просмотра...

Создать модель движения спутника от Земли до Марса
Непрерывная представляется из трех участков: 1) геоцентрического, 2) гелиоцентрического, 3) планетоцентрического. На каждом участке...

3
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8665 / 4502 / 1670
Регистрация: 01.02.2015
Сообщений: 13,926
Записей в блоге: 13
08.03.2017, 19:07
Я её никогда не решал до сдачи, т.к. она была олимпийской задачей. Только на другом форуме обсуждал варианты решения.
Т.к. давать ссылки на другие форумы запрещено, приведу обсуждение. До кода тогда не дошло, т.к. рассуждали мы не торопясь, а олимпиада топикстартера завершилась.
Надеюсь - это поможет.
FPaul:
Я сначала думал, что можно методом половинного деления.
Ведь по одной из стратегий - сначала накапливаются фабрики, потом они выпускают водосборщиков и на следующий день есть N воды. По такой стратегии требуется
(log2 N)+2 = (log2 10^9)+2=30+2=32 дня.
Потом можно было бы придумать критерий - искать день, начиная с которого выпускаются только водовозы или искать соотношение между фабриками и водовозами в ежедневном выпуске.

А с другой стороны - почему бы и не полный перебор - ограничения 2 секунды, и глубина погружения не более 32. Или комбинация перебора с двоичным поиском на каждых сутках.
FPaul:
...при накоплении фабрик их количество удваивается каждый день.
1 день 1 действующая фабрика (ДФ) производит 1 новую фабрику (НФ)
2 день 2 ДФ производят 2 НФ
3 день 4 ДФ производят 4 НФ
.........................
30 день 2^29 ДФ производят 2^29 НФ
31 день 2^30 = 1'073'741'824 ~ 10^9 ДФ производят 2^30 водовозов
32 день фабрики безразличны, а 10^9 водовозов добывают 10^9 воды.
Аатар:
Для такой стратегии и итераций не нужно, просто найти минимальную степень двойки не меньшую N. Для малых N возможны нюансы. Насчет оптимальности вопрос
FPaul:
Да, поэтому и предлагаю или полный перебор, ограниченный 32 днями.
Или рекурсивный спуск с поиском соотношения производства в данный день для достижения минимума (улучшенный перебор). Почему-то ощущение, что будет один "горб=яма" в целевой функции на каждых сутках.
Так что рекурсия вполне применима. На каждом уровне погружения устраиваете цикл от 0 до Nфабрик - столько фабрик будет произведено и передаёте это на следующий уровень. Ограничиваете глубину - 32. После принципиальной работы программы - улучшайте путём сокращения вариантов.
0
0 / 0 / 0
Регистрация: 05.03.2017
Сообщений: 31
08.03.2017, 19:16  [ТС]
Вот именно, я это и читал но все-равно не понял, можете написать тело функции чтобы до меня хоть что-то дошло, рекурсия оч сложно дается
0
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8665 / 4502 / 1670
Регистрация: 01.02.2015
Сообщений: 13,926
Записей в блоге: 13
08.03.2017, 20:35
Нет.
1. Это олимпиада, а не школьное задание.
2. У меня нет возможности проверить.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.03.2017, 20:35
Помогаю со студенческими работами здесь

Написать программу движения 3 тел Солнца, Земли и Марса
Мне нужно написать программу движения 3 тел Солнца, Земли и Марса у меня есть программа движения 2 тел Солнца и Земли я не знаю как...

Частная компания намеревается начать колонизацию Марса к 2023 году
На первый взгляд кажется, что речь идёт об интеллектуальной провокации: частная нидерландская компания Mars One полагает, что...

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


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru