Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Пример работы с... 65535
Содержание сайт... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Модуль Forms 65535
ТЕХНОЛОГИИ ДОСТ... 65257
Имитационное мо... 59095
Реклама
Сейчас на сайте
Гостей: 8
На сайте нет зарегистрированных пользователей

Пользователей: 13,103
новичок: Bayka
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Моделирование ЭВМ на GPSS (три класса заданий) + Пояснительная записка
Моделирование процесса поступления заявок в систему, состоящую из трёх Э...
моделирование процесса поступления заявок в ЭВМ на GPSS + Пояснительная ...

Реклама



Подписывайся на YouTube канал о программировании, что бы не пропустить новые видео!

ПОДПИСЫВАЙСЯ на канал о программировании
Использование программных средств отладки программы. РГРТУ
Лабораторная работа №10
Вариант – 3
(из книги: “Алгоритмизация и программирование на
Турбо Паскале” В.C. Новичков)

Program Proverka;
{*******************************************}
{ Имя программы в банке программ: Lab10v3.pas }
{ Программа: Proverka, Лабораторная работа №10, Вариант 3. }
{ Цель: изучить основные приемы, способы и средства }
{ обнаружения и исправления ошибок в программах, }
{ написанных на языке Турбо Паскаль }
{ Описание параметров и переменных: }
{ a,x,t - аpгументы }
{ an - начальное значение аpгумента a }
{ ak - конечное значение аpгумента а }
{ xn - начальное значение аргумента х }
{ xk - конечное значение аргумента х }
{ kk,nk - число повторений циклов по параметрам К и N }
{ b,b1,b2,b3 - массивы }
{ w - значение функции }
{ k,n,i - паpаметpы цикла }
{ ha - шаг изменения аpгумента a }
{ hx - шаг изменения аpгумента x }
{ j,s,t - вспомогательные переменные }
{ Требуемые подпрограммы: нет. }
{ Метод: использование программных средств отладки программы.}
{ Программист: Борискин Д.В.,гр.243 }
{ Проверил: Новичков В.С.,кафедра ВПМ }
{ Дата написания: 3.12.2002 год. }
{*********************************************}
{$i-}
Uses Crt;
const
max=100;
q=' ******* ';
type
mas=array [1..max] of real;
var
a,ak,an,ha,hx,x,xk,xn,t,w:real;
i,j,k,kk,n,nk,s:integer;
b,b1,b2,b3:mas;
begin {Proverka}
ClrScr;
writeln('Введите начальное значение переменной A ');
read(an);
if (ioresult>0)
then
repeat
writeln('Неправильный ввод. Попробуйте ещё раз! ');
read(an);
until (ioresult=0);
writeln('Введите конечное значение переменной A, число не меньшее ',an:3:2);
read(ak);
if (ioresult>0) or (ak then
repeat
writeln('Неправильный ввод. Попробуйте ещё раз!');
read(ak);
until (ioresult=0) and (ak>=an);
writeln('Введите шаг изменения для параметра A, число большее 0');
read(ha);
if (ioresult>0) or (ha<=0)
then
repeat
writeln('Неправильный ввод. Попробуйте ещё раз!');
read(ha);
until (ioresult=0) and (ha>0);
writeln('Введите начальное положительное значение переменной X ');
read(xn);
if (ioresult>0) or (xn<=0)
then
repeat
writeln('Неправильный ввод. Попробуйте ещё раз!');
read(xn);
until (ioresult=0) and (xn>0);
writeln('Введите конечное значение параметра X, не меньшее ',xn:3:2);
read(xk);
if (ioresult>0) or (xk then
repeat
writeln('Неправильный ввод. Попробуйте ещё раз!');
read(xk);
until (ioresult=0) and (xk>xn);
writeln('Введите шаг изменения для переменной X, число большее 0 ');
read(hx);
if (ioresult>0) or (hx<=0)
then
repeat
writeln('Неправильный ввод. Попробуйте ещё раз!');
read(hx);
until (ioresult=0) and (hx>0);
nk:=trunc((xk-xn)/hx)+1; {Вычисление числа повторений цикла по параметру n}
kk:=trunc((ak-an)/ha)+1; {Вычисление числа повторений цикла по параметру k}
writeln;
readln;
writeln(q,'Начало проверка ввода исходных данных',q);
writeln;
writeln('Начальное значение параметра а = ',an:3:2); {Эхо-печать}
writeln('Конечное значение параметра а = ',ak:3:2); {Эхо-печать}
writeln('Шаг изменения параметра а = ',ha:3:2); {Эхо-печать}
writeln('Начальное значение переменной х = ',xn:3:2); {Эхо-печать}
writeln('Конечное значение переменной х = ',xk:3:2); {Эхо-печать}
writeln('Шаг изменения переменной х = ',hx:3:2); {Эхо-печать}
writeln;
writeln(q,'Конец проверки ввода исходных данных',q);
writeln;
readln;
writeln(q,'Начало проверки внутреннего цикла по параметру А ',q);
writeln(q,' и оператора условия при Х=1 ',q);
writeln;
writeln('Контрольная печать значений полученных в цикле с параметром');
x:=1;
j:=1;
for k:=1 to kk do {начало внутреннего цикла}
begin
a:=an+(k-1)*ha; {вычичление значения пвраметра а}
if a then t:=a/(2*x)
else t:=2*a*x; {конец условного оператора}
w:=x*x*cos(a*x+t); {вычисление значения функции w}
write(' ',w:3:2); {вывод значения функции w}
b[j]:=w; {занесение значений функции w в массив b}
inc(j); {увеличение значения j на единицу}
end; {конец внутреннего цикла}
readln ;
writeln('Конрольная печать значений полученных в цикле с предусловием');
a:=an;
j:=1;
while a<=ak+ha/10 do {начало циклa необходимого для проверки внутреннего цикла}
begin
if a>=x
then t:=2*a*x
else t:=a/(2*x);
w:=x*x*cos(a*x+t);
write(' ',w:3:2);
a:=a+ha;
b1[j]:=w;
inc(j);
end; {конец цикла необходимого для проверки внутреннего цикла}
writeln;
writeln('Сравнение полученных результатов');
for i:=1 to j do
if int(b[i])<>int(b1[i])
then inc(s);
if s=0
then writeln(' Вложенный цикл работает правильно! ')
else writeln(' Вложенный цикл работает неправильно! ');
readln;
writeln(q,' Конец проверки внутреннего цикла по параметру А ',q);
writeln(q,' и оператора условия при Х=1 ',q);
writeln;
readln;
writeln(q,'Начало проверки работы внешнего цикла по переменной Х',q);
writeln;
writeln('Контрольная печать значений полученных в цикле с параметром');
j:=1;
for n:=1 to nk do {начало цикла по переменной Х}
begin
x:=xn+(n-1)*hx;
for k:=1 to kk do {начало вложенного цикла по переменной А}
begin
a:=an+(k-1)*ha;
if a then t:=a/(2*x)
else t:=2*a*x;
w:=x*x*cos(a*x+t);
write(' ',w:3:2);
b3[j]:=w;
inc(j);
end; {конец вложенного цикла по переменной А}
end; {конец цикла по переменной Х}
readln;
writeln('Контрольная печать значений полученных в цикле с предусловием');
x:=xn;
j:=1;
while x<=xk+hx/10 do {начало цикла необходимого для проверки цикла по переменной x}
begin
a:=an;
while a<=ak+ha/2 do {начало вложенного цикла}
begin
if a then t:=a/(2*x)
else t:=2*a*x;
w:=x*x*cos(a*x+t);
write(' ',w:3:2);
b2[j]:=w;
a:=a+ha;
inc(j);
end; {конец вложенного цикла}
x:=x+hx;
end; {конец цикла необходимого для проверки цикла по переменной x}
readln;
writeln('Сравнение полученных результатов');
s:=0;
for i:=1 to j do
 if int(b2[i])<>int(b3[i])
then inc(s);
if s=0
then writeln(' Цикл по параметру Х работает правильно! ')
else writeln(' Цикл по параметру Х работает неправильно! ');
readln;
End.{Proverka}



Опубликовал Kest January 14 2009 18:55:56 · 0 Комментариев · 6202 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
Zoom [Исходник на...
Indy in Depth Глу...
Применение фильтр...
C++ для начинающих
Фундаментальные а...
Усложнённый кальк...
DragMe [Исходник ...
Пример создания W...
Развивающийся фла...
Borland Delphi 8 ...
Учебник для продв...
Delphi Russian Kn...
Генетический алго...
Иллюстрированный ...
Swing. Эффектные...
VFW
Сложный калькулятор
Java 2. Наиболее ...
Правила программи...
С. Г. Горнаков - ...

Топ загрузок
Приложение Клие... 100505
Delphi 7 Enterp... 89502
Converter AMR<-... 20090
GPSS World Stud... 14434
Borland C++Buil... 12503
Borland Delphi ... 8878
Turbo Pascal fo... 7082
Калькулятор [Ис... 5054
Visual Studio 2... 5016
FreeSMS v1.3.1 3552
Случайные статьи
Apply Group Policy...
Программирование: ...
skip(X)
NetWare можгю, уст...
Настройка зон безо...
Запрограммировать ...
Кроме затрат, связ...
файлов
Уже забыли пароль?
Обсуждение структу...
Ввод и вывод данны...
Убрать с экрана пе...
Определяется сущес...
Действия пользователя
Пары «имя-значение»
Интерфейс подпроце...
Моделирование расп...
Основы сетевой рек...
узлами и что сеанс...
Групповые функции
Создание EXE прило...
Приведение типов в...
Вывести все 3х зна...
Объект Shape, свой...
Персептроны
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?