Модераторы: volvo877, Snowy, MetalFan
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> написать рекурсивную функцию, Помогите, не могу сообразить... 
V
    Опции темы
Distemper
Дата 7.1.2008, 11:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 4
Регистрация: 7.1.2008

Репутация: нет
Всего: нет



Не могу сообразить с прогой, помогите плиззз:
ОПРЕДЕЛИТЬ РЕКУРСИВНУЮ ФУНКЦИЮ НА ПАСКАЛЕ, НАХОДЯЩУЮ МИНИМАЛЬНЫЙ ЭЛЕМЕНТ В ОДНОМЕРНОМ МАССИВЕ ЦЕЛЫХ ЧИСЕЛ.
Не могу сообразить, как сделать рекурсию, если массив неопределённый в значениях, т.е. его длина может быть разная... Я думаю как-то через Low и High, но не могу сообразить как...
PM MAIL   Вверх
volvo877
Дата 7.1.2008, 12:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 2073
Регистрация: 15.11.2004

Репутация: 2
Всего: 116



Код

function get_min(const arr: array of integer;
         const size: integer): integer;
var min: integer;
begin
  if size = 1 then get_min := arr[pred(size)]
  else begin
    min := get_min(arr, pred(size));

    if arr[pred(size)] < min then get_min := arr[pred(size)]
    else get_min := min;
  end;
end;

const
  n = 10;
  a: array[1 .. n] of integer = (
    6, 5, 2, -73, 4, -12, 7, 9, 10, 2
  );

begin
  writeln(get_min(a, n));
end.

?
PM MAIL   Вверх
Distemper
Дата 7.1.2008, 13:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 4
Регистрация: 7.1.2008

Репутация: нет
Всего: нет



таким образом, он с конца проверяет массив на меньшее число, да?
почему pred(size), а не dec(size) ?

Это сообщение отредактировал(а) Distemper - 7.1.2008, 13:12
PM MAIL   Вверх
A1taiR
Дата 7.1.2008, 13:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 20
Регистрация: 19.5.2007

Репутация: нет
Всего: нет



Код

if size = 1 then get_min := arr[pred(size)]

Тут у тебя ф-ция выдаст 0, а не 1.
Код

else begin
    min := get_min(arr, pred(size));

По-мойму тут будет бесконечная рекурсия - до нижнего куска кода дело не дойдет.
PM MAIL   Вверх
volvo877
Дата 7.1.2008, 14:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 2073
Регистрация: 15.11.2004

Репутация: 2
Всего: 116



A1taiR, ты б запустил, а потом критиковал, умник... 

Ты в курсе вообще, что такое open array? И что он индексируется с 0? Нет? Так куда лезешь?
PM MAIL   Вверх
A1taiR
Дата 7.1.2008, 15:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 20
Регистрация: 19.5.2007

Репутация: нет
Всего: нет



volvo877
Извеняюсь.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi"
THandle
Rrader
volvo877

Запрещается!

1. Обсуждать и делится взломанными компонентами или программным обеспечением

2. Публиковать ссылки на варез

3. Оффтопить

  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, THandle, Rrader, volvo877.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Object Pascal: кроссплатформенные технологии | Следующая тема »


 




[ Время генерации скрипта: 0.0618 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.