65824

Итерационные алгоритмы

Лабораторная работа

Информатика, кибернетика и программирование

Условие задачи Спецификация программы(SRS) Тест план с результатами выполнения тестов Текст программы 1)Условия задачи: Реализовать программу: В одномерном массиве размерностью N, состоящем из чисел: 1) Найти среднее арифметическое элементов, попадающих в заданный интервал...

Русский

2014-08-06

68 KB

1 чел.

Санкт-Петербургский государственный политехнический университет

Институт информационных технологий и управления

Кафедра «Распределенных вычислений и компьютерных сетей»

ЛАБОРАТОРНАЯ РАБОТА № 2

Итерационные алгоритмы

по дисциплине «Основы программирования »

Выполнил

студент гр. 13507/1  С.С.Недобуга

Преподаватель       Т.Н.Самочадина

Содержание

  1.  Условие задачи
  2.  Спецификация программы(SRS)
  3.  Тест план с результатами выполнения тестов
  4.  Текст программы

1)Условия задачи:

Реализовать программу:

           В одномерном массиве размерностью N, состоящем из чисел:

1) Найти среднее арифметическое элементов, попадающих в заданный интервал [a,b].

2) Многочлены P(x) и Q(x) заданы своими коэффициентами. Определить коэффициенты R(x) = P(x) + Q(x).

2)Спецификация программы

  1.  Массивы должны быть заданы корректно.
    1.  Если аргумент N или N2 не является числом – сообщение “Inccorect N(N2)” .
    2.  Если аргумент N или N2 является числом < 1 – сообщение N(N2) must be greater or equal then 1".
  2.  Элементы массивов должны быть заданы корректно.
    1.  Если какой-либо член массива Mass или Mass2 не является числом – сообщение “ Incorrect member of the Mass(2)”
  3.  Диапазон [a,b] должен быть задан корректно.
    1.  Если аргумент A или B должен быть числом – сообщение “Incorrect value”.
    2.  Если аргумент A>B – сообщение “Incorrect range”.

3)Тест план с результатами выполнения тестов

№ Специф.

Вводимые значения

Вывод

1.1

N = e

Incorrect N

1.2

N2 = 0

N2 must be greater or equal then 1

2.1

Mass[3] = f

Incorrect member of the Mass

3.1

B = %

Incorrect value

3.2

A=5; B=4.5

Incorrect range

4)Текст программы

General.cpp

#include<iostream>

using namespace std;

long double srarf(const double *Mass,const int N);

void sloz(double * M1, int N1, double * M2, int N2, double * M3);

int main(int argc, char **argv)

{

 try

{

 int N;

 double *Mass;

 cout<<"Enter the numbers of massive: ";

 cin>>N;

 if(!cin)throw "Incorrect N";

 if(N<=0)throw "N must be > 0";

 Mass = new double [N];

 cout<<"Coefficients of the polynomial P(x): "<<endl;

 for (int i = 0; i < N; i++)

 {

  cout<<"Mass["<<i+1<<"]: ";

  cin>>Mass[i];

  if(!cin) throw "Incorrect member of the Mass.";

 }

 try

 {

  long double Sr = srarf(Mass,N);

 }

 catch(const int)

 {

  cerr<<"No element in the gap."<<endl;

 }

 int N2;

 double *Mass2;

 cout<<"Enter the numbers of massive 2: ";

 cin>>N2;

 if(!cin)throw "Incorrect N2.";

 if(N<=0)throw "N2 must be > 0.";

 cout<<"Coefficients of the polynomial Q(x): "<<endl;

 Mass2 = new double [N2];

 for (int i = 0; i < N2; i++)

 {

  cout<<"Mass2["<<i+1<<"]: ";

  cin>>Mass2[i];

  if(!cin) throw "Incorrect member of the Mass2.";

 }

 double *Mass3;

 int N3;

 (N>N2)? N3=N : N3=N2;

 Mass3 = new double[N3];

 sloz(Mass,N,Mass2,N2,Mass3);

 cout<<"The coefficients of the polynomial P(x): " <<endl;

 for (int i = 0; i<N; i++)

 {

  cout<<Mass[i]<<"x^"<<i;

  if(i!=(N-1)) cout<<'+';

 }

 cout<<endl;

 cout<<"The coefficients of the polynomial Q(x): " <<endl;

 for (int i = 0; i<N2; i++)

 {

  cout<<Mass2[i]<<"x^"<<i;

  if(i!=(N2-1)) cout<<'+';

 }

 cout<<endl;

 cout<<"The coefficients of the polynomial U(x)=Q(x)+P(x): " <<endl;

 for (int i = 0; i<N3; i++)

 {

  cout<<Mass3[i]<<"x^"<<i;

  if(i!=(N3-1)) cout<<'+';

 }

}

 catch(const char *Err)

{

 cerr<<Err;

 return -1;

}

 return 0;

}

Sloz.cpp

#include<iostream>

void sloz(double * M1, int N1, double * M2, int N2, double * M3)

{

 if (N1>N2)

{

 for (int i = 0; i<N1; i++)

 {

  if (i<N2) M3[i]=M1[i]+M2[i];

  else M3[i]=M1[i];

 }

}

 else 

{

 for (int i = 0; i<N2; i++)

 {

  if (i<N1) M3[i]=M1[i]+M2[i];

  else M3[i]=M2[i];

 }

}

}

Srarf.cpp

#include<iostream>

using namespace std;

long double srarf(const double *Mass,const int N)

{

 long double A, B, Sum=0, Kol=0;

 long double Sr;

std::cout<<"Enter the range [A;B] for arithmetic mean in this range: "<<std::endl;

std::cout<<"A,B: "<<std::endl;

   std::cin>>A>>B;

   if(!std::cin) throw "Incorrect value.";

 if(A>B) throw "Incorrect range.";

 for (int i = 0; i<N; i++)

{

 if ((Mass[i]>=A)&&(Mass[i]<=B))

 {

  Kol++;

  Sum+=Mass[i];

 }

}

 if (Kol == 0) throw 1;

 return((double)Sum/(double)(Kol));

}


 

А также другие работы, которые могут Вас заинтересовать

10190. Технические достижения XIX в. Изобретение радио и двигателя внутреннего сгорания 40 KB
  Технические достижения XIX в. Изобретение радио и двигателя внутреннего сгорания Применение паровой машины на производстве и транспорте обусловило подлинную промышленную революцию XIX в. Механизмом которому было суждено коренным образом изменить жизнедеятельность люд
10191. Развитие средств транспорта в XX – начале XXI вв. Состояние и перспективы железнодорожного дела в современной России 36.5 KB
  Развитие средств транспорта в XX начале XXI вв. Состояние и перспективы железнодорожного дела в современной России Двигатель внутреннего сгорания помог человеку твердо обосноваться в воздушном пространстве. Использование в этих целях паровой машины оказалось неудачн...
10192. Основные этапы освоения космоса. Жизненный путь и научная деятельность К.Э. Циолковского 34 KB
  Основные этапы освоения космоса. Жизненный путь и научная деятельность К.Э. Циолковского Крупные успехи современной тяжелой авиации всецело связаны с использованием реактивного двигателя. Он основан на принципе движения ракеты т.е. противодействии силе термической р
10193. Создание и совершенствование ЭВМ. Роль электроники и компьютерных технологий в современном мире 47.5 KB
  Создание и совершенствование ЭВМ. Роль электроники и компьютерных технологий в современном мире Логическим результатом эволюции радиоэлектронных технологий стало создание ЭВМ. Назвать точную дату изобретения и автора первой электронной вычислительной машины достат
10194. Формирование и развитие системы наука - техника во второй половине ХХ - начале ХХI вв. Задачи гуманитаризации технических наук на современном этапе 30 KB
  Формирование и развитие системы наука техника во второй половине ХХ начале ХХI вв. Задачи гуманитаризации технических наук на современном этапе На современном этапе задачи гуманитаризации науки все более и более актуально встают перед всем человечеством. Это связ...
10195. Образ и его представление, место и метод. Психический аспект образа 60.5 KB
  Образ и его представление место и метод Метод в отношении природы Психический аспект образа. Образ и его представление место и метод По утверждению русского философа В.Ф. Эрна в книге Верховное постижение Платона образ пещеры выдуман сами
10196. Философия как мировоззрение 41 KB
  Философия как мировоззрение: Учение теоретическое т.е. наиболее общее представление о мире и о природе человека и перспективах его познания выраженное в категориях. Насущные вопросы с точки зрения науки Критическое отношение к наукам к обучению стремление больш
10197. От досократиков к Аристотелю: основные проблемы и теоретическая необходимость 755 KB
  От досократиков к Аристотелю: основные проблемы и теоретическая необходимость Ранее были представлены вводные замечания и мы можем двигаться производя примерный хронологический обзор различных предыдущих эпох мысли или практик повлиявших на развитие психологиче...
10198. Краткий обзор представление о нравственности в религии 64 KB
  Краткий обзор представление о нравственности в религии План. 1. Введение. Современность о религии и этике 2. Отношение религии к философии и науке. Премудрость и ее два вида Отношение к ее видам в различные времена 3. Краткий исторический обзор религии в отношении ...