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

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

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

 
 Ответить  Открыть новую тему 
> Функция
klem4
сообщение 14.01.2006 20:27
Сообщение #1


Perl. Just code it!
******

Группа: Модераторы
Сообщений: 4 100
Пол: Мужской
Реальное имя: Андрей

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


Прошу проверить ...

Функция f(n) для целых неотрицательных n определена так :

f(0) = 0, f(1) = 1, f(2n) = f(n), f(2n + 1) = f(n) + f(n + 1).

uses crt;

function f(n : integer) : integer;
begin
if n = 0 then f := 0
else if n = 1 then f := 1
else
if odd(n) then f := f((n-1) div 2) + f((n - 1) div 2 + 1)
else f := f(n div 2);
end;

begin
writeln(f(9));
readln
end.


--------------------
perl -e 'print for (map{chr(hex)}("4861707079204E6577205965617221"=~/(.{2})/g)), "\n";'
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
volvo
сообщение 14.01.2006 20:53
Сообщение #2


Гость






Я бы от одного Else избавился, и убрал кое-что:
function f(n : integer): integer;
begin
if n < 2 then f := n
else
if odd(n) then f := f(n div 2) + f(n div 2 + 1)
else f := f(n div 2);
end;

потому что для нечетного n выражения n div 2 и (n-1) div 2 будут равны...
 К началу страницы 
+ Ответить 

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

 



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