Задача 2960 тестирующая система python

Задача 2960 тестирующая система python

Комментарии

где ответы на питошке

кликай занятие, в нем выбирай задачу

попрошу не писать подобного

Добавить комментарий Отменить ответ

Пн Вт Ср Чт Пт Сб Вс

ЕГЭ на соточку для чайников

Прошу прощения, что так долго пропадал. Питошка вернулся, да еще и с группой в вконтакте, подписывайтесь. Помимо этого, на питошке откроется новая рубрика, в которой будут четкие объяснения всех заданий ЕГЭ и ОГЭ по информатике, внимательно прочитав которые, я уверен, вы улучшите свои баллы на экзамене 🙂

воскресенье, 16 января 2011 г.

Условный оператор

Задача A. Максимум из двух чисел
Даны два целых числа, каждое число записано в отдельной строке. Выведите наибольшее из данных чисел.

Задача B. Високосный год
Требуется определить, является ли данный год високосным. (Напомним, что год является високосным, если его номер кратен 4, но не кратен 100, а также если он кратен 400.)

Задача C. Тестирующая система
В условии одной из задач на этом сайте написано: “Если данное четырехзначное число является симметричным, выведите 1, иначе выведите любое другое целое число”. Для проверки задачи используются заранее подготовленные примеры и правильные ответ на них. Школьнику кажется, что он решил эту задачу, но тестирующая система почему-то не принимает его решение. Школьник думает, что это происходит оттого, что он выводит не то любое другое число, которое записано в правильных ответах.
Напишите программу, которая по ответу, записанному в тестирующей системе и по ответу школьника определяет, верно ли школьник решила задачу. Программа получает на вход два числа: ответ, записанный в тестирующей системе и ответ школьника. Программа должна вывести YES, если школьник дала верный ответ и NO в противном случае.

Задача D. Знак числа
В математике функция sign(x) (знак числа) определена так:
sign(x) = 1, если x > 0,
sign(x) = -1, если x

  1. int n;
  2. cin>>n;
  3. if (n>0)cout if (n if (n==0)cout * This source code was highlighted with Source Code Highlighter .

Задача E. Какое из чисел больше?
Даны два целых числа, каждое записано в отдельной строке. Программа должна вывести число 1, если первое число больше второго, число 2, если второе больше первого, или число 0, если они равны.

  1. int n1,n2;
  2. cin>>n1>>n2;
  3. if (n1>n2 )cout if (n2>n1 )cout if (n1==n2 )cout * This source code was highlighted with Source Code Highlighter .

Задача F. Максимум из трех
Даны три числа, каждое записано в отдельной строке. Выведите наибольшее из данных чисел (программа должна вывести ровно одно целое число).

Задача G. Ладья
Требуется определить, бьет ли ладья, стоящая на клетке с указанными координатами (номер строки и номер столбца), фигуру, стоящую на другой указанной клетке. Вводятся четыре числа: координаты ладьи (два числа) и координаты другой фигуры (два числа), каждое число вводится в отдельной строке.

Задача не требует дополнительных условий, что шахматная доска не может быть больше 8х8, и фигуры не могут находиться в одной клетке.

Задача H. Слон
Требуется определить, бьет ли слон, стоящий на клетке с указанными координатами (номер строки и номер столбца), фигуру, стоящую на другой указанной клетке. Вводятся четыре числа: координаты слона и координаты другой фигуры.

  1. int x1,y1,x2,y2;
  2. cin>>x1>>y1>>x2>>y2;
  3. int dx = x1 — x2;
  4. int dy = y1 — y2;
  5. if (dx if (dy if (dx == dy)
  6. cout "YES" ;
  7. else
  8. cout "NO" ;

* This source code was highlighted with Source Code Highlighter .

Задача не требует дополнительных условий, что шахматная доска не может быть больше 8х8, и фигуры не могут находиться в одной клетке.

Задача I. Ферзь
Требуется определить, бьет ли ферзь, стоящий на клетке с указанными координатами (номер строки и номер столбца), фигуру, стоящую на другой указанной клетке. Вводятся четыре числа: координаты ферзя и координаты другой фигуры.

  1. int x1,y1,x2,y2;
  2. cin>>x1>>y1>>x2>>y2;
  3. int dx=x1-x2;
  4. int dy=y1-y2;
  5. if (dx if (dy if (x1==x2 || y1==y2 || dx==dy)
  6. cout "YES" ;
  7. else
  8. cout "NO" ;

* This source code was highlighted with Source Code Highlighter .

Задача не требует дополнительных условий, что шахматная доска не может быть больше 8х8, и фигуры не могут находиться в одной клетке.

Задача J. Король
Поле шахматной доски определяется парой чисел (a, b), каждое от 1 до 8, первое число задает номер столбца, второе – номер строки. Заданы две клетки. Определите, может ли шахматный король попасть с первой клетки на вторую за один ход.
Даны 4 целых числа от 1 до 8 каждое, первые два задают начальную клетку, вторые два задают конечную клетку. Начальная и конечная клетки не совпадают. Числа записаны в отдельных строках. Программа должна вывести YES, если из первой клетки ходом короля можно попасть во вторую, или NO в противном случае.

  1. int x1,y1,x2,y2;
  2. cin>>x1>>y1>>x2>>y2;
  3. int dx = x1 — x2;
  4. int dy = y1 — y2;
  5. if (dx if (dy if (dx + dy == 1)
  6. cout "YES" ;
  7. else
  8. if (dx + dy == 2 && dx == 1 && dy == 1)
  9. cout "YES" ;
  10. else
  11. cout "NO" ;

* This source code was highlighted with Source Code Highlighter .

Задача не требует дополнительных условий, что шахматная доска не может быть больше 8х8, и фигуры не могут находиться в одной клетке.

Задача K. Конь
Требуется определить, бьет ли конь, стоящий на клетке с указанными координатами (номер строки и номер столбца), фигуру, стоящую на другой указанной клетке. Вводятся четыре числа: координаты коня и координаты другой фигуры.

Задача L. Шоколадка
Требуется определить, можно ли от шоколадки размером n × m долек отломить k долек, если разрешается сделать один разлом по прямой между дольками (то есть разломить шоколадку на два прямоугольника). Вводятся 3 числа: n, m и k; k не равно n × m. Гарантируется, что количество долек в шоколадке не превосходит 30000.

Задача M. Фишки
В каждую крайнюю клетку квадратной доски поставили по фишке. Могло ли оказаться, что выставлено ровно k фишек? (Например, если доска 2 x 2, то выставлено 4 фишки, а если 6 x 6 — то 20).
Вводится одно натуральное число k.

Задача N. Уравнение
Решить в целых числах уравнение ax + b = 0. Вводятся 2 числа: a и b. Необходимо вывести все решения, если их число конечно, “NO” (без кавычек), если решений нет, и “INF” (без кавычек), если решений бесконечно много.

Задача O. Сложное уравнение
Решить в целых числах уравнение ( ax + b ) : ( cx + d ) = 0. Вводятся 4 числа: a, b, c и d; c и d не равны нулю одновременно. Необходимо вывести все решения, если их число конечно, “NO” (без кавычек), если решений нет, и “INF” (без кавычек), если решений бесконечно много.

Задача P. Сдача
Товар стоит a руб. b коп. За него заплатили c руб. d коп. Сколько сдачи требуется получить? Вводятся 4 числа: a, b, c и d. Необходимо вывести 2 числа: e и f, число рублей и копеек, соответственно.

  1. int r1,k1,r2,k2;
  2. cin>>r1>>k1>>r2>>k2;
  3. int rRes = r2 — r1;
  4. int kRes = k2 — k1;
  5. if (kRes // rRes = rRes — 1;
  6. >
  7. cout ‘ ‘ * This source code was highlighted with Source Code Highlighter .

Задача Q. Мороженое
В кафе мороженое продают по три шарика и по пять шариков. Можно ли купить ровно k шариков мороженого?

Задача R. Котлеты
На сковородку одновременно можно положить k котлет. Каждую котлету нужно с каждой стороны обжаривать m минут непрерывно. За какое наименьшее время удастся поджарить с обеих сторон n котлет? Вводятся 3 числа: k, m и n.

  1. int res = 0;
  2. if (n else <
  3. res = 2 * n / k * m;
  4. if (2 * n % k !=0)
  5. res += m;
  6. >
  7. cout * This source code was highlighted with Source Code Highlighter .

Задача S. Координатные четверти
Даны координаты двух точек на плоскости, требуется определить, лежат ли они в одной координатной четверти или нет (все координаты отличны от нуля). Вводятся 4 числа: координаты первой точки (x1, y1) и координаты второй точки (x2, y2).

Задача T. Существует ли треугольник?
Даны три натуральных числа a, b, c, записанные в отдельных строках. Определите, существует ли треугольник с такими сторонами. Если треугольник существует, выведите строку YES, иначе выведите строку NO.

Задача U. Количество равных из трех
Даны три целых числа, записанных в отдельных строках. Определите, сколько среди них совпадающих.
Программа должна вывести одно из чисел: 3 (если все совпадают), 2 (если два совпадают) или 0 (если все числа различны).

  1. int a,b,c;
  2. cin>>a>>b>>c;
  3. if (a == b && b == c)
  4. cout else
  5. if (a == b || b == c || a == c)
  6. cout else
  7. cout * This source code was highlighted with Source Code Highlighter .

Задача V. Квадратное уравнение
Найдите все решения квадратного уравнения ax2 + bx + c = 0.
Вводятся действительные числа a, b, c, a не равно 0.
Выведите два действительных числа, если уравнение имеет два корня, одно действительное число – при наличии одного корня. При отсутствии действительных корней ничего выводить не нужно.

Задача W. Тип треугольника
Определите тип треугольника (остроугольный, тупоугольный, прямоугольный) с данными сторонами. Даны три натуральных числа – стороны треугольника.
Необходимо вывести одно из слов: rectangular для прямоугольного треугольника, acute для остроугольного треугольника, obtuse для тупоугольного треугольника или impossible, если входные числа не образуют треугольника.

Задача X. Коровы
По данному числу n закончите фразу "На лугу пасется. " одним из возможных продолжений: "n коров", "n корова", "n коровы", правильно склоняя слово "корова".
Дано число n (n

  1. int n;
  2. cin>>n;
  3. if ( n%10==0 || (n%10>=5 && n%10 =11 && n " korov" ;
  4. else
  5. if (n%10==1)
  6. cout " korova" ;
  7. else
  8. cout " korovy" ;

* This source code was highlighted with Source Code Highlighter .

Задача Y. Билеты на метро
Билет на одну поездку в метро стоит 15 рублей, билет на 10 поездок стоит 125 рублей, билет на 60 поездок стоит 440 рублей. Пассажир планирует совершить n поездок. Определите, сколько билетов каждого вида он должен приобрести, чтобы суммарное количество оплаченных поездок было не меньше n, а общая стоимость приобретенных билетов – минимальна.
Дано одно число n — количество поездок. Выведите три целых числа, равные необходимому количеству билетов на 1, на 10, на 60 поездок.

  1. const int cost1 = 15, cost10 = 125, cost60 = 440;
  2. int n, k1, k10, k60;
  3. cin >> n;
  4. k60 = n / 60;
  5. n %= 60;
  6. k10 = n / 10;
  7. k1 = n % 10;
  8. if (k1 * cost1 > cost10)
  9. <
  10. k1 = 0;
  11. k10++;
  12. >
  13. if (k1 * cost1 + k10 * cost10 > cost60)
  14. <
  15. k1 = 0;
  16. k10 = 0;
  17. k60++;
  18. >
  19. cout " " " " * This source code was highlighted with Source Code Highlighter .

Задача Z. Билеты на метро – 2
Билет на одну поездку в метро стоит 15 рублей, билет на 5 поездок стоит 70 рублей, билет на 10 поездок стоит 125 рублей, билет на 20 поездок стоит 230 рублей, билет на 60 поездок стоит 440 рублей. Пассажир планирует совершить n поездок. Определите, сколько билетов каждого вида он должен приобрести, чтобы суммарное количество оплаченных поездок было не меньше n, а общая стоимость приобретенных билетов – минимальна.
Дано одно число n — количество поездок. Выведите пять целых чисел, равные необходимому количеству билетов на 1, на 5, на 10, на 20, на 60 поездок. Если для какого-то данного n существует несколько способов приобретения билетов одинаковой стоимости, необходимо вывести ту комбинацию билетов, которая дает большее число поездок.

  1. const int cost1 = 15, cost5 = 70, cost10 = 125, cost20 = 230, cost60 = 440;
  2. int n, k1, k5, k10, k20, k60;
  3. cin >> n;
  4. k60 = n / 60;
  5. n %= 60;
  6. k20 = n / 20;
  7. n %= 20;
  8. k10 = n / 10;
  9. n %= 10;
  10. k5 = n/5;
  11. k1 = n % 5;
  12. if (k1 * cost1 >= cost5)
  13. <
  14. k1 = 0;
  15. k5++;
  16. >
  17. if (k1 * cost1 + k5 * cost5 >= cost10)
  18. <
  19. k1 = 0;
  20. k5 = 0;
  21. k10++;
  22. >
  23. if (k1 * cost1 + k5 * cost5 + k10 * cost10 >= cost20)
  24. <
  25. k1 = 0;
  26. k5 = 0;
  27. k10 = 0;
  28. k20++;
  29. >
  30. if (k1 * cost1 + k5 * cost5 + k10 * cost10 + k20 * cost20 >= cost60)
  31. <
  32. k1 = 0;
  33. k5 = 0;
  34. k10 = 0;
  35. k20 = 0;
  36. k60++;
  37. >
  38. cout " " " " " " " " * This source code was highlighted with Source Code Highlighter .
  1. int m,n,x,y;
  2. cin>>m>>n>>x>>y;
  3. if (x!=1) cout " " if (x!=m) cout " " if (y!=1) cout " " if (y!=n) cout " " * This source code was highlighted with Source Code Highlighter .

Задача AB. Апельсины бочками
Бизнесмен Василий после прочтения известной книги решил открыть новый бизнес – отгружать апельсины бочками. Партнерам важно знать сколько именно бочек апельсинов отгружается каждый день. Мобильный телефон Василия поддерживает только транслит, поэтому он передает сообщения вида "N bochek" . Например, "3 bochki" или "1 bochka" .
Напишите программу, которая выбирает правильное слово (из "bochka" , "bochek" , "bochki" ) в зависимости от N (0 ≤ N ≤ 1000).

Задача AC. Четные и нечетные числа
Даны три целых числа A, B, C. Определить, есть ли среди них хотя бы одно четное и хотя бы одно нечетное.
A, B, C не превышают по модулю 10000. Вывести – "YES" или "NO" .

Задача AD. Римская система счисления
Дано число X (1 ≤ X ≤ 100). Требуется перевести это число в римскую систему счисления.

  1. int x;
  2. cin>>x;
  3. int x1,x10;
  4. x1=x%10;
  5. x10=x/10;
  6. if (x10==1) cout "X" ;
  7. if (x10==2) cout "XX" ;
  8. if (x10==3) cout "XXX" ;
  9. if (x10==4) cout "XL" ;
  10. if (x10==5) cout "L" ;
  11. if (x10==6) cout "LX" ;
  12. if (x10==7) cout "LXX" ;
  13. if (x10==8) cout "LXXX" ;
  14. if (x10==9) cout "XC" ;
  15. if (x10==10) cout "C" ;
  16. if (x1==1) cout "I" ;
  17. if (x1==2) cout "II" ;
  18. if (x1==3) cout "III" ;
  19. if (x1==4) cout "IV" ;
  20. if (x1==5) cout "V" ;
  21. if (x1==6) cout "VI" ;
  22. if (x1==7) cout "VII" ;
  23. if (x1==8) cout "VIII" ;
  24. if (x1==9) cout "IX" ;

* This source code was highlighted with Source Code Highlighter .

Задача AE. Упорядочить три числа
Дано три числа, записанный в отдельных строках. Упорядочите их в порядке неубывания. Программа должна считывать три числа a, b, c, затем программа должна менять их значения так, чтобы стали выполнены условия a

  1. int a,b,c,t;
  2. cin>>a>>b>>c;
  3. if (a>b) swap(a,b);
  4. if (a>c) swap(a,c);
  5. if (b>c) swap(b,c);
  6. cout " " * This source code was highlighted with Source Code Highlighter .

Пишу свою тестирующую систему (Python). Кто хочет присоеддиниться к проекту ?

  • dudeboy
  • 9 лет назад
  • 20

Система частично написана, но довести до ума не хватает, много нюансов надо учесть.

Само тестирование предполается с помощью testlib (чтобы не изобретать велосипед).

Да, серверная часть тестирующей самое узкое место.

Ejudge не устраивает настройкой, и для простого школьного сервера она сильно тяжелая.

У меня есть мысль создать следующую тестирующую систему. Все на модулях: модуль для работы с клиентами(в нем есть модули страниц (модуль страницы отправки решений(тоже может быть композитным из серии решение — число, решение — программа, решение — выберите вариант ответа и т.п.), модуль таблицы результатов (разные таблицы могут предоставлять разную информацию о результатах), модуль просмотра всех посылок и т.п.)), модуль сервера проверки (главный модуль, который будет направлять решение по разным модулям, модуль проверки стиля, модуль компиляции, модуль запуска, модуль проверки решения, модуль оценки решения и т.п.)

При такой системе можно с легкостью менять правила соревнования (подменяем главный модуль тестирования, в нем пару инструкций заменяем и все), менять систему соревнования (несложно, например, сделать систему для проведения code game challenge), менять часть для работы с клиентами (изменить оформление, таблицу результатов и т.п.).

Если кто-то соберется делать что-то подобное или решит мне помочь — дайте мне знать.

Ссылка на основную публикацию
Доработка вега 110 стерео
Вопрос: Добрый день, Анатолий Павлович! Интересует оптимальный способ чистки (мойки) виниловых пластинок. Современные (широко рекламируемые) средства мойки, не говоря уже...
Демонстрационная математическая модель полета снаряда
1.1. Запустить программу «Демонстрационная математическая модель». Познакомиться с работой модели в режиме без учета сопротивления воздуха и с учетом сопротивления...
Деталь бросается в ванну а затем вымывается
Тема 8. Особенности разговорного стиля. Чистота речи. Морфологические нормы: употребление форм глагола. Речевая избыточность и речевая недостаточность. Стилистическая оценка жаргона....
Егиссо не удается отобразить эту страницу
Код этой ошибки, как правило, появляется на экране при переходе на служебный или государственный web-сайт. Яркий пример – официальный портал...
Adblock detector