![]() |
|
|
Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
![]() |
|
Опции темы | Поиск в этой теме | Опции просмотра |
|
#1
|
||||
|
||||
![]() Код:
var Form1: TForm1; M,N,S:integer; implementation {$R *.dfm} procedure TForm1.Button1Click(Sender: TObject); begin M:=StrToInt(Edit1.Text); N:=StrToInt(Edit2.Text); if M>N then M:=M-N else N:=N-M; while M=N do begin ShowMessage('Наибольший общий делитель найден!'); S:=M; Edit3.Text:=IntToStr(S); end; end; end. Объясню проблему: Даны два натуральных числа, нужно найти наибольший общий делитель. Для этого... 1) если числа равны, взять одно из них для ответа, если нет то 2 2) заменить большее число разностью большего и меньшего из чисел (M-N) 3) Вернуться к выполнению п.1. То-есть, нужно повторять операцию выявления максимального числа и замены его на разность максимального и минимального, до того, как получатся равные числа и тогда одно из равных чисел будет взято за ответ. Цикл то я вроде правильно задал, вот с повтором не могу разобраться... Вот пример: M=32 N=24 M>N, true, M:=32-24; M:=8; M>N, false, N:=24-8; N:=16; M>N; false, N:=16-8; N:=8; M=N; Ответ:=M =(( Помогите пожалуйста |
#2
|
|||
|
|||
![]() Думаю это ты хотел:
Код:
procedure TForm1.Button1Click(Sender: TObject); var M,N:Integer; begin M:=StrToInt(Edit1.Text); N:=StrToInt(Edit2.Text); while (M<>N) and (M>1) and (N>1) do if M>N then Dec(M,N) else Dec(N,M); if (M=N) then Edit3.Text:=IntToStr(M) else Edit3.Text:='Нет общего делителя'; end; |
#3
|
||||
|
||||
![]() Огромное спасибо за помощь, надеюсь в следующий раз подобных вопросов не возникнет.
|