<< Вернуться на главную Сортировка атомов(2012г)СОРТИРОВКА АТОМОВВНИМАНИЕ!!!До очного этапа осталось несколько дней!Регистрация на очный этап состоится в субботу, 31 марта в 10ч30мРегистрация будет на первом этаже СЮТПросьба не опаздывать, опаздавшему достанется самый слабый компьютер :-)Для тех кто в первый раз сраничка во время заочного этапа На очном этапе соискателям будут предложены 3-и задания очень похожие на задание заочного этапа. Там будут те же роботы, такие же способы управления и контроля, но условия этих 3-х заданий будут немного изменены. Изменены не сильно, но достаточно, чтобы вам пришлось "адаптировать" вашу программу под них (а то вдруг, на заочном этапе вы не сами писали?). За 4-ре часа вы должны получить максимальные результаты во всех трех заданиях. Ну а дальше все просто. Победитель будет определен по сумме очков всех заданий (так что бороться нужно за каждое очко!). В этом году спонсором конкурса выступает "РОСАТОМ". Ожидаются участники из других городов края. Традиционно,в нашем конкурсе будут 2-е номинации. Отдельно 8-9 классы и 10-11.
УСЛОВИЯ КОНКУРСА Одной из больших проблем является проблема переработки ядерных отходов. Недавние события на АЭС "ФУКУСИМА" показали, что эта проблема является очень и очень серьезной. Нами предлагается новейшая система очистки, состоящая из множества микророботов, которые будут работать под управлением вашей программы. В емкости, где находятся роботы растворены атомы 3-х типов Тип =1 - радиоактивные изотопы, Тип =2 - окислитель и Тип =3 - нейтральные атомы. Робот может анализировать тип атома, который ему доступен в текущий момент. для этого существует функция "M_GET". Управляется робот при помощи подпрограммы "M_RAB" (применение описано ниже). Каждый робот может взять до 9-ти атомов (после чего команда "взять" перестает выполняться). За каждый взятый атом первого типа дается одно очко. Кроме роботов на игровом поле находятся утилизаторы (синие квадратики), которые служат для переработки атомов. Если координаты робота совпадают с координатами утилизатора, то робот разгружается. Если в утилизаторе скапливаются атомы 1-го и 2-го типа, То они вступают в реакцию и за каждую пару дается еще два очка. Всего на миссию дается 3000 ходов. Один ход - это когда будут выданы команды не всех роботов. ВНИМАНИЕ! если вы выдадите команду на робота, которым уже ходили в этом цикле, то программа автоматически считает ход сделанным! Ваша задача - набрать макимальное количество очков. Смотрите исходники проектов, задавайте вопросы. Для успеха необходимо построить коллективную систему управления роботами. Кстати, на очном этапе условия будут изменены и за 4-ре часа необходимо будет переделать свою программу для получения большей эффективности (А то вдруг программу вы не сами писали?).
Игрушку с ручным управлением для вникания в проблему можно скачать
здесь Итак, приступаем собственно к заданию. Для разных облочек программирования (C++BUIlDER, DELPHI2007, LAZARUS) мы подготовили проекты, в которых роботы двигаются по случайному закону и ловят атомы первого(радиоактивного) типа. Это "затравка" для вашей программы. В проекте специально выделена подпрограмма пользователя которую вам и необходимо модифицировать. Остальные части проекта трогать нежелательно, во избежание потери работоспособности. Размер сосуда 640 на 640 пикселов. В задаче заочного этапа имеется 100 роботов и 50 утилизаторов. УПРАВЛЕНИЕ РОБОТАМИ
Для управления применяется подпрограмма M_RAB(N,KOM); N - Номер робота (от 1 до MAX_ROB) KOM - Команда =1 - Влево =2 - Вверх =3 - Вправо =4 - Вниз =5 - Взять ближайший атом (выполнится если такой атом есть, и робот не заполнен)Внимание! {Если параметры будут ошибочными, то последствия могут быть непредсказуемы!)А если в том месте, куда вы хотите сходить уже есть другой робот, то ход выполнен не будет! КОНТРОЛЬ
Узнать, какой тип атома сейчас может быть взят роботом можно через функцию M_GET(N)
(Где N - номер робота). Кроме того, В ходе работы программы вам доступны основные параметры,
которые вам выдаются в виде готовой структуры: Для LAZARUSA и DELPHI **************************************************************** // описание робота T_ROB=PACKED RECORD X,Y:INTEGER;// координаты KOL:BYTE; // количество пойманных атомов END; // описание утилизатора T_UTIL=PACKED RECORD X,Y:INTEGER;// координаты END; // ОСНОВНАЯ СТРУКТУРА T_STRUK=PACKED RECORD MAX_ROB:INTEGER; // Количество роботов MAX_UTIL:INTEGER;// Количество утилизаторов KOL_HOD:INTEGER; // количество оставшихся ходов SCORE: INTEGER; // Очки MR:PACKED ARRAY[1..MAX_ROB]OF T_ROB; // Массив роботов MU:PACKED ARRAY[1..MAX_UTIL]OF T_UTIL;// Массив утилизаторов END; для С++BUILDERA **************************************************************** // описание робота struct T_ROB{ public: int X; // координаты int Y; // координаты Byte KOL;// количество пойманных атомов } ; // описание утилизатора struct T_UTIL{ public: int X;// координаты int Y;// координаты } ; // ОСНОВНАЯ ТРУКТУРА struct T_STRUK{ public: int MAX_ROB; // Количество роботов int MAX_UTIL; // Количество утилизаторов int KOL_HOD; // Оставшееся количество ходов int SCORE; // Очки T_ROB MR[100];// Массив роботов T_UTIL MU[50];// Массив утилизаторов } ; } ; // ВНИМАНИЕ !!! ввиду известных особенностй // реализации массивов на языке "С", нумерация в массивах "сдвинута" // Например номера роботов идут от 1 до 100 а нумерация в массиве от 0 до 99.
Например:
А здесь выложены готовые проекты, которые вам нужно будет подправить
для достижения наибольшего результата. Учтите, что работать
Можно на си или паскале
Проект для Lazarus (Предпочитается) На очном этапе необходимо будет адаптировать свою программу под слегка измененные условия. Обещаем, что на очном этапе ожидаются сюрпризы! Но я думаю, что для тех, кто напишет программу на заочном этапе и разберется во всем сам, ничего страшного не будет :-). Очный этап состоится 31 марта. По результатам очного этапа будут вручены грамоты и призы.
По всем вопросам обращайтесь к администрации "звездного мира" через систему или по почте |