помогите пожалуйста в организации процедуры! я только новичек в Паскале
Вот описание
Составить программу для нахождения наименьшего общего кратного 3 натуральных чисел
Вот фрагмент программы, го она не работает! Даже есть скриншот!!
ПОМОГИГЕ, PLEASE
program LAb_14;
uses crt;
var a,b,c:0..9;
z:integer;
procedure vvod(a,b,c:byte);
Var i:byte;
begin
read(a,b,c);end;
procedure nok(a,b,c:byte;var z:integer);
var i,x:byte;
begin
if ((a div a)<>0)and((b div a)<>0)and((c div a)<>0) then x:=x+1;
x:=z;
end;
begin
clrscr;
writeln('Введите 3 натуральных числа');
vvod(a,b,c);
writeln('Наименьшее общее кратное 3 чисел=');
nok(a,b,c,z);
readln;
end.
как ты думаешь, что будет происходить в этой строчке
if ((a div a)<>0)and((b div a)<>0)and((c div a)<>0) then x:=x+1;при а=0?
if ((a div a)<>0)and((b div a)<>0)and((c div a)<>0) then x:=x+1;при а=0?
function GCD (A: integer; B: integer): integer;если хочешь одной функцией, можеш посмотретьhttp://alglib.sources.ru/translator/dl/numbers.lcm.delphi.zip, только подправь возращение результата функцией...
{Наибольший Общий Делитель}
begin
while (a <> 0) and (b <> 0) do
if a >= b then
a := a mod b
else
b := b mod a;
GCD := a + b; { один - ноль }
end;
function LCM (A: integer; B: integer): integer;
{Наименьшее Общее Кратное}
begin
LCM := a * b div GCD (a, b)
end;
function GCD (A: integer; B: integer): integer;если хочешь одной функцией, можеш посмотретьhttp://alglib.sources.ru/translator/dl/numbers.lcm.delphi.zip, только подправь возращение результата функцией...
{Наибольший Общий Делитель}
begin
while (a <> 0) and (b <> 0) do
if a >= b then
a := a mod b
else
b := b mod a;
GCD := a + b; { один - ноль }
end;
function LCM (A: integer; B: integer): integer;
{Наименьшее Общее Кратное}
begin
LCM := a * b div GCD (a, b)
end;
function GCD (A: integer; B: integer): integer;
{Наибольший Общий Делитель}
begin
while (a <> 0) and (b <> 0) do
if a >= b then
a := a mod b
else
b := b mod a;
GCD := a + b; { один - ноль }
end;
function LCM (A: integer; B: integer): integer;
{Наименьшее Общее Кратное}
begin
LCM := a * b div GCD (a, b)
end;
procedure nod(const a, b, c:integer;var r:integer);
{твоя процедура) }
begin
r:=LCM(LCM(a, b), c);
end;
{пример вызова}
var a, b, c, res:integer;
begin
write('>>'); readln(a);
write('>>'); readln(b);
write('>>'); readln©;
NOD(a, b, c, res);
writeln('NOD=', res);
end.
uses crt;
procedure nok(var a,b:integer);
var
m:integer;
begin
if a>b then m:=a
else m:=b;
while (m mod a<>0) or (m mod b <>0) do
inc(m);
b:=m
end;
var
a,b,c:integer;
begin
clrscr;
writeln(' Vvedite 3 chisla: ');
readln(a,b,c);
nok(a,b);
nok(b,c);
writeln(' NOK= ',c);
readkey
end.
Все спасибо большое
THANK YOU!!!!!!!!!!!!!!!!!!!!!!