Написать программу, которая выводит таблицу квадратов первых пяти целых
положительных нечетных чисел в обратном порядке
209
328
Ответы на вопрос:
PascalABC.NET 3.5.1
begin
var start := ReadInteger('С какого числа начинаем? ');
for var i := start downto 1 do PrintLn(i*i);
end.
Вариант понимания условия №1. мы достаём монеты по одной, и порядок монет важен (т.е., например, если мы вытащили сначала монету 1 рубль, потом 5 рублей и если сначала 5 рублей, потом 1 рубль - разные способы). обозначим c(n) - число способов набрать n рублей. очевидно, c(n) = c(n-1) + c(n-2) + c(n-5) + c(n-10) [представим себе. что мы знаем число способов набрать n-5 рублей. тогда если мы уверены, что последней вытащили 5-рублёвую монету, то способов будет c(n). финальный ответ - сумма по всем возможным выборам последней монеты] полагая c(n) = 0 при всех n < 0, c(0) = 1, получим по этой формуле с(66) = 1431020833989040 cчитать можно, например, такой программой: var c: array[-9..66] of biginteger; begin for var i : = -9 to -1 do c[i] : = 0; c[0] : = 1; for var i : = 1 to 66 do c[i] : = c[i - 1] + c[i - 2] + c[i - 5] + c[i - 10]; print(c[66]); end. вариант понимания условия №2 . нам порядок выдачи не важен. тогда вопрос по сути сводится к числу целых неотрицательных решений уравненияx + 2y + 5z + 10t = 66, где x, y, z, t - число 1-, 2-, 5- и 10-рублёвых монет соответственно. тут можно написать общую формулу, но она будет объемной, так что вычислять по ней совсем не радостно (даже с компьютером). поэтому проще все варианты перебрать. ответ получится 700. пример программы: begin var count : = 0; for var t : = 0 to 6 do for var z : = 0 to (66 - 10*t) div 5 do for var y : = 0 to (66 - 10*t - 5*z) div 2 do inc(count); print(count); end. подобным образом можно считать и вручную. по сути нам требуется вычислить сумму [1 + (66 - 10t - 5z)/2] по всем допустимым t, z ([x] - целая часть x). перебираем сначала t, потом z: t = 0. z = 0,1,. вклад в сумму 34 + 31 + 29 + 26 + 24 + 21 + 19 + 16 + 14 + 11 + 9 + 6 + 4 + 1 = 245. t = 1. z = 0,1,. легко понять, что здесь будут все числа без первых двух слагаемых: 29 + 26 + 24 + 21 + 19 + 16 + 14 + 11 + 9 + 6 + 4 + 1 = 245 - 34 - 31 = 180 аналогично, t = 2: 180 - 29 - 26 = 125 t = 3: 125 - 26 - 21 = 80 t = 4: 80 - 19 - 16 = 45 t = 5: 45 - 14 - 11 = 20 t = 6: 20 - 9 - 6 = 5 итого 245 + 180 + 125 + 80 + 45 + 20 + 5 = 700
Популярно: Информатика
-
tukacheva8828.03.2020 07:39
-
МорскойКот15.03.2022 05:14
-
artemka10617.06.2021 11:30
-
Nemiroffdenisa26.12.2022 01:00
-
mashkasuper118.07.2022 18:44
-
Sima12105.01.2023 19:03
-
veraway14009.01.2021 03:27
-
voronbakhozs9gh05.03.2021 13:39
-
tanyapishulovaoyc3lb22.10.2022 07:29
-
snowpanzer05.10.2022 07:57