Навигация
Главная
Поиск
Форум
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
Реклама
Сейчас на сайте
Гостей: 24
На сайте нет зарегистрированных пользователей

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

Принадлежит ли точка пересечению двух окружностей на Turbo Pascal + Отче...
Моделирование работы перекрёстка по регулированию движения на GPSS + Поя...
Моделирование работы ЭВМ на GPSS + Пояснительная записка

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

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
Preview
THttpScan v4.1
AddPage [Исходник...
Globus VCL Extent...
Abc_component
IIIDTrans
EditNew
Язык программиров...
Генетический алго...
PBFoldder
Использование Lis...
isoCanvas (Редакт...
Философия C++. Пр...
Degisy Data Acces...
Х. М. Дейтел, П. ...
C++ Стандартная б...
Indy in Depth Глу...
Таймер и секундомер
PHP 5 для "чайников"
Цветной Grid

Топ загрузок
Приложение Клие... 100772
Delphi 7 Enterp... 97809
Converter AMR<-... 20261
GPSS World Stud... 17014
Borland C++Buil... 14189
Borland Delphi ... 10267
Turbo Pascal fo... 7372
Калькулятор [Ис... 5972
Visual Studio 2... 5206
Microsoft SQL S... 3661
Случайные статьи
Модули форм
Сортировка числово...
Выполнение агрегир...
Поиск в упорядочен...
Где купить укрывно...
РАЗДЕЛЫ КНИГИ
Если Windows Messe...
Значки с логотипом...
Операторы описания...
Что делает маска п...
Игры. Игромания
Глава 1. Риск: ос...
Управление трафико...
Определить принадл...
Протокол MEGACO
PowerShell для Вин...
Взаимодействие с о...
Потолки Екатеринбург
Мониторинг
Класс TManager
Запись и чтение об...
Дополнительная лит...
Конкурсы для воспи...
Что напоминает кон...
HR. Старайтесь исп...
Статистика



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


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