Версия для печати темы

Нажмите сюда для просмотра этой темы в обычном формате

Форум «Всё о Паскале» _ Задачи _ прцедура

Автор: zoha 4.01.2008 1:54

помогите пожалуйста в организации процедуры! я только новичек в Паскале

Вот описание

Составить программу для нахождения наименьшего общего кратного 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.



Эскизы прикрепленных изображений
Прикрепленное изображение

Прикрепленные файлы
Прикрепленный файл  ZOHA14.PAS ( 413 байт ) Кол-во скачиваний: 277

Автор: compiler 4.01.2008 2:00

как ты думаешь, что будет происходить в этой строчке

if ((a div a)<>0)and((b div a)<>0)and((c div a)<>0) then x:=x+1;
при а=0?

и вообще я не понял алгоритма... ИМХО, проще всего будет решить считая НОК(a, b, c) = НОК(НОК(a, b), c)

Автор: zoha 4.01.2008 2:43

Цитата(compiler @ 4.01.2008 0:00) *

как ты думаешь, что будет происходить в этой строчке
if ((a div a)<>0)and((b div a)<>0)and((c div a)<>0) then x:=x+1;
при а=0?

и вообще я не понял алгоритма... ИМХО, проще всего будет решить считая НОК(a, b, c) = НОК(НОК(a, b), c)




А как это сделать ПОМОГИ пажалуйста фрагмент напиши

Автор: compiler 4.01.2008 3:37

Цитата(zoha @ 3.01.2008 21:43) *
А как это сделать ПОМОГИ пажалуйста фрагмент напиши
а у гугла спросить слабо? вот например так пишут на сурсах http://www.sources.ru/wiki/doku.php?id=pascal:math&s=%D0%BD%D0%B0%D0%B8%D0%BC%D0%B5%D0%BD%D1%8C%D1%88%D0%B5%D0%B5+%D0%BE%D0%B1%D1%89%D0%B5%D0%B5+%D0%BA%D1%80%D0%B0%D1%82%D0%BD%D0%BE%D0%B5..
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;
если хочешь одной функцией, можеш посмотретьhttp://alglib.sources.ru/translator/dl/numbers.lcm.delphi.zip, только подправь возращение результата функцией...

Автор: zoha 5.01.2008 14:13

Цитата(compiler @ 4.01.2008 1:37) *

а у гугла спросить слабо? вот например так пишут на сурсах http://www.sources.ru/wiki/doku.php?id=pascal:math&s=%D0%BD%D0%B0%D0%B8%D0%BC%D0%B5%D0%BD%D1%8C%D1%88%D0%B5%D0%B5+%D0%BE%D0%B1%D1%89%D0%B5%D0%B5+%D0%BA%D1%80%D0%B0%D1%82%D0%BD%D0%BE%D0%B5..
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;
если хочешь одной функцией, можеш посмотретьhttp://alglib.sources.ru/translator/dl/numbers.lcm.delphi.zip, только подправь возращение результата функцией...



Можно ли организовать процедуру к этой задаче.
Буду благодарен за фрагмент порграаммы
Заранее спасибо!!!!! nea.gif nea.gif nea.gif

Автор: compiler 5.01.2008 16:24

Цитата(zoha @ 5.01.2008 9:13) *

Можно ли организовать процедуру к этой задаче.
Буду благодарен за фрагмент порграаммы
Заранее спасибо!!!!! nea.gif nea.gif nea.gif
а что я тебе написал? или тебе надо именно procedure?

Автор: zoha 6.01.2008 17:23

Цитата(compiler @ 5.01.2008 14:24) *

а что я тебе написал? или тебе надо именно procedure?



Да именно procedura нужна ПОМОГИТЕ ПОЖАЛУЙСТА
nea.gif nea.gif nea.gif

Автор: compiler 6.01.2008 17:57

Цитата(zoha @ 6.01.2008 12:23) *
Да именно procedura нужна
можна написать так...
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.

Автор: zoha 7.01.2008 18:55

Цитата(compiler @ 6.01.2008 15:57) *
можна написать так...
мне нужно нок, ане нод

Автор: Client 7.01.2008 19:25

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.

Цитата(compiler @ 3.01.2008 22:00) *

проще всего будет решить считая НОК(a, b, c) = НОК(НОК(a, b), c)
А у меня он почему-то на это стал ругаться...

Автор: volvo 7.01.2008 19:47

Цитата
А у меня он почему-то на это стал ругаться...
Потому, что Var-параметры используешь, компилятор ждет переменную, а вызов функции - это не переменная...

Автор: compiler 8.01.2008 2:50

Цитата(zoha @ 7.01.2008 13:55) *
мне нужно нок, ане нод
переименнуй)) лол...

оффтоп
да... кажется, я последнее время начал буковки путать)


Автор: zoha 8.01.2008 23:18

Все спасибо большое
THANK YOU!!!!!!!!!!!!!!!!!!!!!! good.gif good.gif good.gif