Дана последовательность вещественных чисел, заданная в типизированном файле. Методом индуктивной функции вычислить среднюю длину связных подпоследовательностей отрицательных чисел.
Что здесь можно сделать?
| Olya |
Сообщение
#1
|
![]() Новичок ![]() Группа: Пользователи Сообщений: 18 Пол: Женский Реальное имя: Olya Репутация: 0 |
Дана последовательность вещественных чисел, заданная в типизированном файле. Методом индуктивной функции вычислить среднюю длину связных подпоследовательностей отрицательных чисел. Что здесь можно сделать? |
![]() ![]() |
| Lapp |
Сообщение
#2
|
![]() Уникум ![]() ![]() ![]() ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 6 823 Пол: Мужской Реальное имя: Лопáрь (Андрей) Репутация: 159 |
Короче, вот..
В твоей программе слишком много нужно было переделывать, и мне очень не хотелось тянуть твои громоздкие названия в такой простой программе. Выкладываю текст работающей программы в надежде, что ты разберешься сама, что к чему. Поясню только основной момент, про индуктивную функцию. Индуктивной, грубо говоря, называется функция, которую можно посчитать через предыдущий результат. В нашем случае, перед считыванием очередного числа мы как бы уже имеем длину текущей цепочки. Считываемое число либо оборвет ее, либо увеличит на единицу. То есть предыдущий результат лтбо фиксируется, либо увеличивается и смотрится, что там дальше. Иначе говоря, на каждом этапе мы должны воспользоваться результатом предыдущего этапа. А это значит, что можно использовать то, что в программировании называется рекурсия: вызов функции из тела самой этой функции. Именно это и характеризует индуктивность функции (одного названия, увы, недостаточно Посмотри внимательно на тело функции, особенно присвоение: NegChainL:=NegChainL+1 В левой части стоит значение, которое возвратит функция по окончании своей работы, а в правой то же самое слово представляет собой последующий вызов этой же функции. Это и есть рекурсия (в переводе на русский - повторный вход). При этом в стеке создается еще одна копия всех данных этой функции, так что, например, переменная a в ней уже не равна переменной a в вызвавшей функции. Программный код же используется тот же самый. Вложенных вызовов может быть очень много - сколько позволит размер стека. Если стек переполнится, программа свалится, но в нашем случае такое вряд ли случится - несколько десятков вложений вполне нормально. Данные читай из файла negchain.dat - по одному чилу на строке. Я не написал никаких комментариев - добавь их, пожалуйста, сама. И покажи тут, что у тебя получилось. Успехов! {Average negative chain length calculating}
-------------------- я - ветер, я северный холодный ветер
я час расставанья, я год возвращенья домой |
Olya Метод индуктивной функции..часть 2 27.03.2007 2:33
Lapp Если честно, непонятно..
Я бы не назвал функцию … 27.03.2007 2:55
prednisone without a prescriptio Cialis 36 Heures 14.11.2021 12:30
Olya Вот попытка написать подпрограмму, проверяйте:
:b… 27.03.2007 12:26
Lapp Ну, неплохо! :)
Наворочено, конечно... ладно,… 27.03.2007 12:55
Lapp Olya, давай договоримся: ты будешь сама пробовать … 27.03.2007 14:13
Olya :)[i]Андрей, приветик, вот проверяй...а ты уверен,… 28.03.2007 12:50
Lapp Что проверять? комментарии? они программу не портя… 28.03.2007 13:22
how does plaquenil work for lupu Amoxil Safe During Breastfeeding 21.09.2021 21:21
how long does gabapentin stay in Priligy Nous 10.12.2021 16:50
generic valtrex overnight delive Isotretinoin For Sale Internet 19.12.2021 0:41![]() ![]() |
|
Текстовая версия | 4.11.2025 0:52 |