Главная » Просмотр файлов » В.Г. Абрамов, Н.П. Трифонов, Г.Н. Трифонова - Введение в язык Паскаль

В.Г. Абрамов, Н.П. Трифонов, Г.Н. Трифонова - Введение в язык Паскаль (1107618), страница 21

Файл №1107618 В.Г. Абрамов, Н.П. Трифонов, Г.Н. Трифонова - Введение в язык Паскаль (В.Г. Абрамов, Н.П. Трифонов, Г.Н. Трифонова - Введение в язык Паскаль) 21 страницаВ.Г. Абрамов, Н.П. Трифонов, Г.Н. Трифонова - Введение в язык Паскаль (1107618) страница 212019-04-28СтудИзба
Просмтор этого файла доступен только зарегистрированным пользователям. Но у нас супер быстрая регистрация: достаточно только электронной почты!

Текст из файла (страница 21)

Известно, что этот процесс сходится при любом начальномприближении у ( ° \ При этом практически можно считать, что требуемаяточность достигнута, когда очередная учтенная поправка v~ ^ по абсолютной величине оказалась меньше значения е.Ясно, что этот процесс носит циклический характер: после задания начального приближенияв качестве которого можно, например, принятьединицу, дальнейшие вычисления сводятся к многократному вычислениюочередной поправки и очередного приближения к искомому результату:у: = 1; и: =(х/у - у)/2; у:=у + и; и: = (х/у - у)/2; у:=у+ и; ...Этот процесс должен закончиться в тот момент, когда окажется, чтодля получения очередного приближения (значения у) использоваласьпоправка и такая, что | v | < е.Очевидно, что в общем случае число повторений этого цикла заранеенеизвестно, а его определение равносильно решению поставленной задачи.В подобного рода случаях мы можем лишь сформулировать условие,при выполнении которого этот циклический процесс должен завершиться.Для задания таких вычислительных процессов в паскале и служит оператор цикла с постусловием.

Этот оператор цикла имеет видrepeats, S; .. . ; S untU Вгде repeat (повторять) и until (до) — служебные слова, через S обозначенлюбой оператор, а через В — логическое выражение.При выполнении этого оператора цикла последовательность операторов,находящаяся между символами repeat и until, выполняется один или болеераз. Этот процесс завершается, когда после очередного выполнения задан75ной последовательности операторов логическое выражение В примет (впервые) значение true. Таким образом, с помощью логического выражения Взадается условие завершения выполнения оператора цикла. Посколькув данном случае проверка условия производится после выполенения заданной последовательности операторов, этот оператор цикла и называетсяоператором цикла с постусловием.С использованием этого вида оператора цикла метод Ньютона извлеченияквадратного корня можно реализовать по следующему алгоритму (eps имя константы, представляющей заданную точность) :у:=1;repeat v:=(х/у-у)/2;у:=y+v untilabs(v)<epsЗаметим, что оператор цикла с постусловием является более общим,чем оператор цикла с параметром — любой циклический процесс, задаваемый с помощью оператора цикла с параметром, можно задать и с использованием оператора цикла с постусловием.

Действительно, оператор циклавидаfor V: = Е 1 to Е2 do Sэквивалентен следующей последовательности операторов:if Е 2 > Е 1 thenbegin V: =Е1;repeat S; V: = succ(V) until V > E2endВ частности, алгоритм решения рассматривавшейся ранее задачи суммирования гармонического ряда можно сформулировать и с использованиемоператора цикла с постусловием:у:=0;i:=1;repeat у:=у+1/i;i:=i+l untili>nОднако в ряде случаев оператор цикла с параметром обеспечивает болеекомпактную и наглядную запись алгоритма.4.5.3. Оператор цикла с предусловиемВ случае оператора цикла с постусловием входящая в него последовательность операторов заведомо будет выполняться хотя бы один раз. Междутем довольно часто встречаются такие циклические процессы, когда числоповторений цикла тоже неизвестно заранее, но при некоторых значенияхисходных данных предусмотренные в цикле действия вообще не должнывыполняться, и даже однократное выполнение этих действий может привести к неверным или неопределенным результатам.Пусть, например, дано вещественное число М.

Требуется найти наименьшее Целое неотрицательное число к, при котором 3 > М . Эту задачу можнорешить по следующему алгоритму: предварительно положить у = 1 и к = 0;затем в цикле домножать значение у на 3 и увеличивать значение к на единицу — до тех пор, пока текущее знамение у впервые окажется больше значения М. На первый взгляд, здесь можно воспользоваться оператором76цикла с постусловием:у: =1;к:=0;repeat у: =у*3;к:=к + 1 until у>МОднако нетрудно убедиться в том, что при М < 1 будет получен неправильный результат к = 1, тогда как должно быть получено к = 0: в этом случаепредварительно сформированное значение к = 0 является окончательнымрезультатом и действия, предусмотренные в цикле, выполняться недолжны.Для задания подобного рода вычислительных процессов, когда числоповторений цикла заранее неизвестно и действия, предусмотренные в цикле, могут вообще не выполняться, и служит оператор цикла с предусловием.

Этот оператор цикла имеет видwhile В do Sгде while (пока) , do (делать, выполнять) — служебные слова, В — логическое выражение, S — оператор. Здесь оператор S выполняется повторнонуль или более раз, но перед каждым очередным его выполнением вычисляется значение выражения В, и оператор S выполняется только в томслучае, когда выражение В принимает значение true. Выполнение операторацикла завершается, когда выражение В впервые примет значение false.Если это значение выражение В примет при первом же его вычислении,то оператор S не выполнится ни разу.

Поскольку здесь условие завершенияциклического процесса проверяется до выполнения оператора S, то оператор цикла данного вида и называется оператором цикла с предусловием.В рассматриваемой нами задаче правильное значение к при любом значении М может быть получено по следующему алгоритму, в котором используется оператор цикла с предусловием:у : = 15 к : = 0 ;while у<М do begin у: J»y*3; к: =к + 1 endЗаметим, что оператор цикла с предусловием является наиболее универсальным — с использованием таких операторов можно задать и циклические процессы, определяемые операторами цикла с параметром и постусловием. Например, оператор цикла с параметромfor V: = El to Е2 do Sэквивалентен следующей последовательности операторов:V: = Е 1 ;while V < Е2 do begin S; V: = succ(V) endОператор цикла с постусловием обычно также можно свести к оператору цикла с предусловием, соответствующим образом изменив логическоевыражение В.

Например, рассмотренную ранее задачу извлечения квадратного корня с заданной точностью можно решить и по такому алгоритмус использованием оператора цикла с предусловием:у: = 1 ; v • = 1;while abs<v)>epsdo begin v:«(x/y-y)/2;у:=y+vend77При использовании операторов цикла с предусловием и постусловиемнеобходимо быть осторожным в тех случаях, когда в условии фигурируютвещественные переменные. Необходимость такой осторожности проиллюстрируем на следующем примере.Пусть требуется подсчитать сумму значений некоторой функции f ( x )в узлах сетки, получаемой разбиением заданного отрезка [d, b\, где b>d,на п равных частей, включая границы отрезка:s=п2 /(*,•),i=огде Xj = d + ih,h = (b-d)/n(/=0,1n).Фрагмент программы (считая заданными значения вещественных переменных d, b и целочисленной переменной п ) , предназначенный для вычисления s, кажется довольно естественным записать следующим образом(взяв для определенности f ( x ) = х * х) :h : = (b -d ) /п; s:=0; x:=d-h;repeatx : =>: +h; в: =s+x*xuntil >:=bили, используя оператор цикла с предусловием, в видеh: = (b-d) /л; s:=0; x:=x-h;while x#b dobegin x : =>:+h; s: =s+x*x endОднако на самом деле оба эти алгоритма некорректны, хотя с математической точки зрения они совершенно правильны В чем же состоит этанекорректность?Вспомним, что вещественные числа представляются в машине, вообщеговоря, неточно.

Например, вещественное число 1.0 может быть представлено как число 0.999999 или как число 1.000001. Поэтому машинные представления значений d u b могут несколько отличаться от их заданныхзначений. Кроме того, и арифметические операции над вещественнымичислами выполняются не точно, а по правилам действий над приближенными числами (т.е. результат округляется по тому или иному принятомув машине правилу). По этой причине значение х, полученное в результатеи-кратного прибавления значения h к значению d, может быть чуть большеили чуть меньше значения Ь, а точное совпадение этих значений являетсяслучайностью.Таким образом, условие х - Ъ, фигурирующее в приведенных вышеоператорах цикла, скорее всего никогда не будет выполняться, в результате чего произойдет "зацикливание" программы - цикл будет выполняться неопределенно долго, пока какое-либо из вычисляемых значений не окажется больше максимального допустимого в машине числа, и по этойпричине выполнение программы будет принудительно прекращено операционной системой.78Для избежания такого зацикливания условие окончания цикла следовало бы сформулировать несколько иначе, например:repeatх: =x+h; s: =s+x*xuntil x>bВ этом случае зацикливания программы не произойдет, но может возникнуть более коварная ошибка.

Действительно, если последнее подлежащее учету значение х случайно окажется чуть меньше значения Ъ, то циклповторится один лишний раз. Это, естественно, внесет ошибку в значение sза счет учета лишнего слагаемого. Особенно неприятно то, что влияниеэтой ошибки на окончательный результат зависит от характера поведенияфункции на заданном отрезке, так что при не очень удачно подобраннойфункции, на которой будет производиться проверка программы, эту ошибку можно и не заметить. При последующем же использовании этой программы для некоторых конкретных функций может получаться совершеннонеправдоподобный результат.Так что во всех случаях, когда для получения правильного результатанеобходимо обеспечить совершенно определенное число повторений цикла,следует избегать использования вещественных значений для целей управления циклом.

Характеристики

Тип файла
PDF-файл
Размер
2,47 Mb
Тип материала
Высшее учебное заведение

Список файлов книги

Свежие статьи
Популярно сейчас
Как Вы думаете, сколько людей до Вас делали точно такое же задание? 99% студентов выполняют точно такие же задания, как и их предшественники год назад. Найдите нужный учебный материал на СтудИзбе!
Ответы на популярные вопросы
Да! Наши авторы собирают и выкладывают те работы, которые сдаются в Вашем учебном заведении ежегодно и уже проверены преподавателями.
Да! У нас любой человек может выложить любую учебную работу и зарабатывать на её продажах! Но каждый учебный материал публикуется только после тщательной проверки администрацией.
Вернём деньги! А если быть более точными, то автору даётся немного времени на исправление, а если не исправит или выйдет время, то вернём деньги в полном объёме!
Да! На равне с готовыми студенческими работами у нас продаются услуги. Цены на услуги видны сразу, то есть Вам нужно только указать параметры и сразу можно оплачивать.
Отзывы студентов
Ставлю 10/10
Все нравится, очень удобный сайт, помогает в учебе. Кроме этого, можно заработать самому, выставляя готовые учебные материалы на продажу здесь. Рейтинги и отзывы на преподавателей очень помогают сориентироваться в начале нового семестра. Спасибо за такую функцию. Ставлю максимальную оценку.
Лучшая платформа для успешной сдачи сессии
Познакомился со СтудИзбой благодаря своему другу, очень нравится интерфейс, количество доступных файлов, цена, в общем, все прекрасно. Даже сам продаю какие-то свои работы.
Студизба ван лав ❤
Очень офигенный сайт для студентов. Много полезных учебных материалов. Пользуюсь студизбой с октября 2021 года. Серьёзных нареканий нет. Хотелось бы, что бы ввели подписочную модель и сделали материалы дешевле 300 рублей в рамках подписки бесплатными.
Отличный сайт
Лично меня всё устраивает - и покупка, и продажа; и цены, и возможность предпросмотра куска файла, и обилие бесплатных файлов (в подборках по авторам, читай, ВУЗам и факультетам). Есть определённые баги, но всё решаемо, да и администраторы реагируют в течение суток.
Маленький отзыв о большом помощнике!
Студизба спасает в те моменты, когда сроки горят, а работ накопилось достаточно. Довольно удобный сайт с простой навигацией и огромным количеством материалов.
Студ. Изба как крупнейший сборник работ для студентов
Тут дофига бывает всего полезного. Печально, что бывают предметы по которым даже одного бесплатного решения нет, но это скорее вопрос к студентам. В остальном всё здорово.
Спасательный островок
Если уже не успеваешь разобраться или застрял на каком-то задание поможет тебе быстро и недорого решить твою проблему.
Всё и так отлично
Всё очень удобно. Особенно круто, что есть система бонусов и можно выводить остатки денег. Очень много качественных бесплатных файлов.
Отзыв о системе "Студизба"
Отличная платформа для распространения работ, востребованных студентами. Хорошо налаженная и качественная работа сайта, огромная база заданий и аудитория.
Отличный помощник
Отличный сайт с кучей полезных файлов, позволяющий найти много методичек / учебников / отзывов о вузах и преподователях.
Отлично помогает студентам в любой момент для решения трудных и незамедлительных задач
Хотелось бы больше конкретной информации о преподавателях. А так в принципе хороший сайт, всегда им пользуюсь и ни разу не было желания прекратить. Хороший сайт для помощи студентам, удобный и приятный интерфейс. Из недостатков можно выделить только отсутствия небольшого количества файлов.
Спасибо за шикарный сайт
Великолепный сайт на котором студент за не большие деньги может найти помощь с дз, проектами курсовыми, лабораторными, а также узнать отзывы на преподавателей и бесплатно скачать пособия.
Популярные преподаватели
Добавляйте материалы
и зарабатывайте!
Продажи идут автоматически
6376
Авторов
на СтудИзбе
309
Средний доход
с одного платного файла
Обучение Подробнее