Во вложении приведен рисунок, из которого видно принятое расположение треугольника. Треугольник прямоугольный и уравнение его гипотенузы можно получить из формулы уравнения прямой в отрезках. Алгоритм решения следующий. 1. Вводим значения a и b. 2. Очищаем переменную счетчика количества k нулём. 3. В цикле по х от 0 с шагом 1 до целой части b: - вычисляем целую часть y, найденного из приведенного уравнения - увеличиваем k на эту целую часть плюс 1 4. Выводим значение k.
Проверим этот алгоритм для нашего рисунка. a=3, b=4, y=³/₄(4-x), k=0 Для х=0 получаем у=3 и увеличиваем k на 3+1=4, т.е. k=4 Для х=1 получаем у=2.25, целая часть 2 и увеличиваем k на 2+1=3, т.е. k=7 Для х=2 получаем у=1.5, целая часть 1 и увеличиваем k на 1+1=2, т.е. k=9 Для х=3 получаем у=0.75, целая часть 0 и увеличиваем k на 0+1=1, т.е. k=10 Для х=4 получаем у=0, целая часть 0 и увеличиваем k на 0+1=1, т.е. k=11 Значение 11 выводим. Из рисунка видно, что точек действительно 11.
1. Современное решение
// PascalABC.NET 3.2, сборка 1425 от 22.04.2017 // Внимание! Если программа не работает, обновите версию!
begin var a,b:real; Write('Введите значения a и b через пробел: '); Read(a,b); Writeln(Range(0,Trunc(b)).Select(x->Trunc(a/b*(b-x))+1).Sum) end.
Контрольный пример Введите значения a и b через пробел: 3 4.0 11
2. Школьное решение в стиле ТурбоПаскаль 1983г.
var a,b,y:real; k,x:integer; begin Write('Введите значения a и b через пробел: '); Read(a,b); k:=0; for x:=0 to Trunc(b) do begin y:=a/b*(b-x); k:=k+Trunc(y)+1 end; Writeln(k) end.
Предположим, что последовательность же задана, то есть вводить ее мы не будем. Последовательность представляет собой массив чисел а. n:=1; k:=0; for i:=1 to 100 do if (a[i]<0) then k:=k+1; проверяем наличие отрицательных if (k=0) then writeln("Отрицательных нет.") else begin for i:=1 to 100 do if (a[i]<0) then n:=a[i]; находим хотя бы один отрицательный for i:=1 to 100 do if ((a[i]<0) AND (a[i]>n) then n:=a[i]; находим наибольший отрицательный writeln("Наибольшее из отрицательных чисел данной последовательности - ",n); end; end.
Алгоритм решения следующий.
1. Вводим значения a и b.
2. Очищаем переменную счетчика количества k нулём.
3. В цикле по х от 0 с шагом 1 до целой части b:
- вычисляем целую часть y, найденного из приведенного уравнения
- увеличиваем k на эту целую часть плюс 1
4. Выводим значение k.
Проверим этот алгоритм для нашего рисунка.
a=3, b=4, y=³/₄(4-x), k=0
Для х=0 получаем у=3 и увеличиваем k на 3+1=4, т.е. k=4
Для х=1 получаем у=2.25, целая часть 2 и увеличиваем k на 2+1=3, т.е. k=7
Для х=2 получаем у=1.5, целая часть 1 и увеличиваем k на 1+1=2, т.е. k=9
Для х=3 получаем у=0.75, целая часть 0 и увеличиваем k на 0+1=1, т.е. k=10
Для х=4 получаем у=0, целая часть 0 и увеличиваем k на 0+1=1, т.е. k=11
Значение 11 выводим.
Из рисунка видно, что точек действительно 11.
1. Современное решение
// PascalABC.NET 3.2, сборка 1425 от 22.04.2017
// Внимание! Если программа не работает, обновите версию!
begin
var a,b:real;
Write('Введите значения a и b через пробел: '); Read(a,b);
Writeln(Range(0,Trunc(b)).Select(x->Trunc(a/b*(b-x))+1).Sum)
end.
Контрольный пример
Введите значения a и b через пробел: 3 4.0
11
2. Школьное решение в стиле ТурбоПаскаль 1983г.
var
a,b,y:real;
k,x:integer;
begin
Write('Введите значения a и b через пробел: '); Read(a,b);
k:=0;
for x:=0 to Trunc(b) do begin
y:=a/b*(b-x);
k:=k+Trunc(y)+1
end;
Writeln(k)
end.
n:=1; k:=0;
for i:=1 to 100 do if (a[i]<0) then k:=k+1; проверяем наличие отрицательных
if (k=0) then writeln("Отрицательных нет.") else begin
for i:=1 to 100 do if (a[i]<0) then n:=a[i]; находим хотя бы один отрицательный
for i:=1 to 100 do if ((a[i]<0) AND (a[i]>n) then n:=a[i]; находим наибольший отрицательный
writeln("Наибольшее из отрицательных чисел данной последовательности - ",n);
end;
end.