Навигация
Главная
Поиск
Форум
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
21 ошибка прогр... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Пример работы с... 65535
Содержание сайт... 65535
ТЕХНОЛОГИИ ДОСТ... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Имитационное мо... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Реклама
Сейчас на сайте
Гостей: 7
На сайте нет зарегистрированных пользователей

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

База данных студентов на Delphi (файл записей) + Блок схемы
Моделирование литейного цеха на GPSS + Пояснительная записка
Лабораторная работа по динамическим спискам на Turbo Pascal (перемещение...

Использование программных средств отладки программы. РГРТУ
Лабораторная работа №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 15:55:56 · 0 Комментариев · 7694 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
EMS QuickExport S...
Error mod
DateEdit
Email
EMSQuickImport
3D Тетрис [Исходн...
Приемы программир...
SysInfo [Исходник...
Dnavigator
netBIOS
Delphi 6. Учебный...
Стелтинг Стивен, ...
THttpScan v4.1
Srinilist
Игра PackMan
C++ : библиотека ...
PHP/MySQL для нач...
API (Применение A...
CS:Source - монит...
Delphi и технолог...

Топ загрузок
Приложение Клие... 100800
Delphi 7 Enterp... 98063
Converter AMR<-... 20302
GPSS World Stud... 17068
Borland C++Buil... 14261
Borland Delphi ... 10388
Turbo Pascal fo... 7398
Калькулятор [Ис... 6093
Visual Studio 2... 5241
Microsoft SQL S... 3676
Случайные статьи
Листинг 17.2. Сайт...
Решения к главе 4
Броня
Рабочие станции
Катушки оптом
Введение в создани...
Язык С: литералы с...
Конфигурация серве...
Как правильно подо...
Занятие 3, Распрос...
Создание файла сод...
Подписанное сообще...
Статический импорт...
String constant ex...
Классификация и ст...
STORAGE (ПАМЯТЬ)
Состав нового меню...
Ответы см
Управление изменен...
Оператор «плюс» (+)
Как работать с абз...
Windows 2000 подде...
Кабель с перекрест...
Выдача команд на у...
Итерационное плани...
Статистика



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


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