Int a:array[1..4, 1..4] of integer;
i, j, k: integer;
begin
k:=0;
for i:=1 to 4 do
for j:=1 to 4 do begin
readln(a[i, j]);
If (i=j) and (a[i] < 0) and (a[i] mod 2 = 0) then
k:= k+1;
end;
writeln(k);
end.
- Double
- Int64
- Double
- Int32
- Double
- Int32
- Double
- Double
Взято с помощью функции GetType при a = 16. При дробном a не будет выполняться 4 пункт, а другие же изменятся. Тут нужно подробно рассмотреть ситуации. Пусть у нас целочисленная переменная a. Тогда:
- Функция корня (sqrt) всегда возвращает тип double. Почему? Ведь у нас может быть табличное значение? Объясняю: не всегда может выпасть табличное значение, поэтому наше число типа integer расширяется до double (при этом не теряя никаких знаков, а в случае, если бы мы сужали с double к integer - у нас бы была потеря знаков) и нам уже неважно, получили мы дробное или целое - всё сохранится в переменной типа double. А ещё мы делим на целочисленное и у нас точно вся дробь превращается в тип double.
- Здесь уже будет зависеть от того, какая переменная a. Если она целочисленная, то она может быть очень большой, поэтому результат расширяется до BigInteger или же Int64. Если рациональная, дробная, то double.
- Здесь всегда будет тип double, поскольку в функции Abs (взятие модуля) мы от числа отнимаем рациональное и расширяем переменную до double.
- Здесь мы не можем принимать рациональные, дробные и так далее - только целочисленные. Соответственно, ответ будет типа integer.
- Как бы странно не прозвучало, но функция int, возвращающая целую часть выведет тип double, но ответ будет целочисленным. "Смех" здесь в том, что эта функция принимает любые числа, а не только вещественные.
- В отличие от предыдущего примера функция trunc принимает лишь вещественные числа, поэтому типом будет int.
- Frac возвратит лишь дробную часть, поэтому не стоит удивляться, почему оно возвращает double.
- Думаю, тут даже комментировать ничего не нужно. Попробуйте в любом калькуляторе ввести sin(какой-то_угол) и Вы всё поймёте.
===== PacalABC.NET =====
begin
var L := ReadReal('Укажи расстояние до танка:');
Writeln('Программа завершается при попадании в танк');
Writeln('или при вводе числа, не попадающего в диапазон от 0 до 90');
var (g, v0, eps) := (9.81, 100.0, 1.0);
while True do
begin
var a := ReadReal('Введи угол наклона пушки, град:');
if not a.InRange(0.0, 90.0) then Exit;
var d := L - Sqr(v0) * Sin(2 * DegToRad(a)) / g;
if Abs(d) <= eps then
begin
Println('Ура! Попадание!');
Exit
end
else if d > 0 then
Println('Недолет')
else
Println('Перелет')
end
end.