В кафе продается мороженое по 3 или по 5 шариков в порции. Определить, можно ли купить K шариков мороженного.
5-9 класс
|
Входные данные:
Во входном потоке в первой строке задано натуральное число К (K <= 1000)
Выходные данные:
Вывести YES или NO.
Пример входного файла (input.txt):
2
x: - входное число, целое
а: - целое
шаг 1.
x - делится на 5 ?
если да то ответ YES, выход
шаг 2.
а: = x-5*целое (х/5)
шаг 3
a - делится на 3 ?
если да то ответ YES, выход
шаг 4
a:=a+5
шаг 5
a - больше чем х ?
если да то ответ NО, выход
переход на шаг 3
1. Решение для сомневающихся и привыкших писать программы безмозгло "в лоб"
var
k, p, q: integer;
flag: boolean;
f:Text
begin
Assign(f,'input.txt');
Reset(f);
read(f,k);
Close(f);
case k of
1, 2, 4, 7: writeln('NO');
3, 5: writeln('YES');
else
q := k mod 5;
if (q = 0) or (k = 3) then writeln('YES')
else
begin
q := (k div 5);
flag := false;
while (not flag) and (q > 0) do
begin
p := k - 5 * q;
if p mod 3 = 0 then
begin
writeln('YES');
flag := true
end;
q := q - 1
end;
if (not flag) then writeln('NO')
end
end
end.
2. Решение в соответствии с алгоритмом, приведенным в комментарии к вопросу.
const
Kno = [1, 2, 4, 7];
var
k: integer;
f:Text
begin
Assign(f,'input.txt');
Reset(f);
read(f,k);
Close(f);
if k in Kno then writeln('NO')
else writeln('YES')
end.
Комментарий удален
нам крупно повезло, что задача сводится к отфильтровке чисел 1 2 4 7
так как в условии задано 3 и 5 шариков
а если бы их было не 3 и 5
а например 11 и 13 или не дай бог еще большие
тогда массив чисел 1 2 4 7 значительно вырос бы
высмеянное Вами решение в лоб легко справится с поставленной задачей
у программистов ведь принято сводить задачу к ранее решенной
Комментарий удален
Комментарий удален
Комментарий удален
Другие вопросы из категории
сообщения: 5-отлично, 4-хорошо, 3-нормально, 2 плохо на языке Паскаля
ВЛАЖНОСТЬЮ ВОЗДУХА. РЕЗУЛЬТАТОТ ОДНОГО ИЗМЕРЕНИЧ ЯВЛЯЕТСЯ ЦЕЛОЕ ЧИСЛО ОТ 0 ДО
100 ПРОЦЕНТОВ, КОТОРОЕ ЗАПИСЫВЕТСЯ ЦЕЛЫМ ЧИСЛОМ БИТ. СТАНЦИЯ СДЕЛАЛА 200 ИЗМЕРЕНИЙ.ОПРЕДЕЛИТЕ ИНФОРМАЦИОННЫЙ ОБЪЕМ
РЕЗУЛЬТАТОВ НАБЛЮДЕНИЯ.
Читайте также
Программа Паскаль
Даны три переменные вещественного типа: A, B, C. Если их значения упо- рядочены по возрастанию или убыванию, то удвоить их; в противном слу- чае заменить значение каждой переменной на противоположное. Вывести новые значения переменных A, B, C.