IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> рекурсионная возведение в степень, некак неполучается рекурсией
maksimla
сообщение 7.11.2009 18:24
Сообщение #1


Знаток
****

Группа: Пользователи
Сообщений: 324
Пол: Мужской
Реальное имя: maksim

Репутация: -  1  +


Иногда нужна пользоватся экономическим возведением в какуето степень. Чтобы использовать как менше множетелей операций функции надо использовать эти примечание
Прикрепленное изображение
в скобках написано b четное число
Написать программу которая реализировала экономочный число возведение в степень (с клавиатуры вводим натуральные числа n и m (0 < n ≤ 5, 0 < m ≤ 10), а на экране выводим n число в степени m). Нахождения степени должно быть выражено через рекурсированную функцию.

Я написал программу простую с возведением в степень с процедурой и экономичным или экономическим вариантом но без рекурсии

Program ekokel;
var n,m,a:longint;
procedure kel(n,m:integer);
begin
a:=1;
while m>0 do
begin
a:=a*n;
dec(m);
end;
end;
begin
writeln('введите число n от 0 до 5');
readln(n);
writeln('введите число m от 0 до 10');
readln(m);
if m mod 2 = 0 then begin
kel(n, m div 2);
a:=a*a
end
else kel(n,m);
writeln(a);
readln
end.



а с рекурсированной функцией получается неправильно

Program ekokel;
var n,m,a:longint;
function kel(n,m:integer):integer;
begin
if m>0 then begin n:=n*n; writeln('n= ',n); kel(n,m div 2); end;
end;
begin
writeln('введите число n от 0 до 5');
readln(n);
writeln('введите число m от 0 до 10');
readln(m);
if m mod 2 = 0 then begin
kel(n, m div 2);
a:=a*a
end
else kel(n,m);
writeln(a);
readln
end.


может подскажете как надо делать


--------------------
Учусь первый год на программиста в колледже. Учусь на втором курсе в школе программирования при научно-исследовательском институте математики и информатики.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
volvo
сообщение 7.11.2009 19:11
Сообщение #2


Гость






Нет тут никакого переполнения:
function kel(n, m: longint): longint;
begin
if m = 0 then kel := 1
else
if m = 1 then kel := n
else
kel := sqr(n) * kel(n, m - 2);
end;
, проверил со всеми передаваемыми значениями. Если число МОЖЕТ быть вычислено, и помещается в тип LongInt, выдается правильный результат.
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 22.06.2025 0:58
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"