Дан алгоритм на языке грис шаг шаг шаг поворот поворот поворот поворот шаг прыжок поворот шаг шаг шаг поворот поворот поворот шаг прыжок поворот шаг шаг шаг поворот поворот поворот поворот шаг прыжок поворот
(запишите этот алгоритм с использованием процедуры
Вспомним формулу для n-го члена арифметической прогрессии и получим из нее n.
В соответствии с условиями нашей задачи это будет верно, если a1 и an - нечетные. Если a1 четное, то его надо уменьшить на 1. Аналогично, если an четное, его надо увеличить на 1. Таким образом, мы получаем алгоритм, пригодный для быстрого определения количества нечетных чисел на любом интервале с целочисленными границами.
Ниже приводится соответствующая программа.
program p11;
var
a,b,n:integer;
begin
Write('Введите границы интервала: '); Readln(a,b);
{ защита от неверного порядка ввода }
if a<b then begin n:=a; a:=b; b:=n end;
{ если надо, корректируем границы на нечет }
if (a mod 2)=0 then a:=a-1;
if (b mod 2)=0 then b:=b+1;
{ сам расчет }
n:=(a-b) div 2 + 1;
Writeln('Количество нечетных чисел на интервале равно ',n)
end.
Тестовое решение:
Введите границы интервала: -3 7
Количество нечетных чисел на интервале равно 6
1.2 В противоположность предложенному решению, где сначала надо было думать, можно использовать "метод грубой силы" (программисты называют его "брутфорс" - от английского bruteforce), т.е. программировать ни о чем не думая.
Ниже - пример такого решения. Оно более короткое, но при больших интервалах время решения окажется на несколько порядков больше.
program p12;
var
a,b,i,k:integer;
begin
Write('Введите границы интервала: '); Readln(a,b);
{ защита от неверного порядка ввода }
if a<b then begin k:=a; a:=b; b:=k end;
k:=0;
for i:=a downto b do
if (i mod 2)<>0 then k:=k+1;
Writeln('Количество нечетных чисел на интервале равно ',k)
end.
Тестовое решение:
Введите границы интервала: -3 7
Количество нечетных чисел на интервале равно 6
2.1. Тут задача на первый взгляд стандартная и вроде бы думать нечего - в цикле накапливаем сумму:
program p21;
var
i:integer;
x,s:real;
begin
Write('Введите значение x: '); Readln(x);
s:=0; i:=2;
while i<=20 do begin s:=s+i*x; i:=i+2 end;
Writeln('Cумма членов последовательности равна ',s)
end.
Тестовое решение:
Введите значение x: 2.15
Cумма членов последовательности равна 236.5
2.2. Но и тут есть место для размышлений. Опять вспоминаем математику.
Но полученная сумма - это сумма арифметической прогрессии с начальным членом, равным единице, конечным членом, равным 10 и разностью 1. Формула такой суммы известна и мы продолжаем преобразования.
Теперь можно и программу написать.
program p22;
var
x:real;
begin
Write('Введите значение x: '); Readln(x);
Writeln('Cумма членов последовательности равна ',110*x)
end.
Тестовое решение:
Введите значение x: 2.15
Cумма членов последовательности равна 236.5
Пары приведенных решений призваны показать, что первое пришедшее в голову решение обычно всегда не лучшее. А еще - что для качественного программирования надо учить математику.
{ Задача по информатике решить в паскале Имеется продуктовая база в которой можно
закупить партию товара по условиям минимальная стоимость , близость поставки ,
прочность товара Если товар удолетворяет - закупаем
Если ее удолетворяет - не закупаем
Мы вводим данные близость поставки, прочность товара, и минимальная стоимость
если все три условия выполняются ввыводим закупаем а
если не выполняются выводи не закупается}
type
WareData = record
MinPrice: integer;
Distance: integer;
Strength: real;
end;
var
Base, Client: WareData;
begin
Base.MinPrice := 4;
Base.Distance := 57;
Base.Strength := 0.25;
read(Client.MinPrice, Client.Distance, Client.Strength);
if (Client.MinPrice >= Base.MinPrice)
and (Client.Distance >= Base.Distance)
and (Client.Strength <= Base.Strength) then
writeln('Берем')
else
writeln('Не устраивает');
end.