Форум программистов, компьютерный форум CyberForum.ru

составить блок-схемы по коду - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Произведение элементов массива, расположенных между максимальным и минимальным элементами http://www.cyberforum.ru/cpp-beginners/thread890411.html
Всем приветик. Подскажите пожалуйста как подсчитать произведение элементов массива, расположенных между максимальным и минимальным элементами. max и min я нашла. #include <iostream.h> #include <conio.h> void main() { int n; // n - количество элементов в массиве int a; // a - массив целых чисел, максимальный размер 100 элементов cout<<"vvedite kol. elementov >20 : "<<endl; cin >>...
C++ ООП для начинающих (создать класс для выполнения операций с двумерными векторами) Задание первого курса по Visual C++ Создать класс для выполнения операций с двумерными векторами. Считать, что компоненты имеют целый тип. Осуществить перегрузки операций: “ ^ ” – расчет модуля вектора; “ + ” – скалярное произведение векторов; “ == ”, “ != ” – равенство, неравенство векторов; “ ― ” – найти расстояние между двумя векторами. http://www.cyberforum.ru/cpp-beginners/thread890375.html
Из заданного текстового файла создать новый файл C++
Из заданного текстового файла создать новый файл при помощи циклической замены Заглавных гласных на «+1», строчных гласных на «–1», согласных на «+2», прочих символов на «+5».
как создать универсальную функцию для случайного заполнения массива? C++
Само задание вот: Задание 1. Определение максимального подъёма в массиве Написать программу, заполняющую случайным образом массив из n элементов. (n=30). Диапазон значений элементов от 0 до 99. Сделать массив глобальным. Написать функцию, выводящую массив на экран print_array(). Написать функцию поиска максимального подъёма в массиве по его размеру и выводящую размер и длину максимального...
C++ Из последовательности чисел y1,y2,...,yn выбрать элементы, делящиеся на 3 http://www.cyberforum.ru/cpp-beginners/thread890348.html
Одномерные массивы: 1)Из последовательности чисел y1,y2,...,yn выбрать элементы, делящиеся на 3. Подсчитать их число и напечатать их порядковые номера. Спасибо большое.
C++ Найти максимальную разность соответствующих компонент двух векторов Одномерные массивы: 2)Даны два вектора по 10 компонент в каждом. Найти максимальную раз-ность соответствующих компонент и порядковый номер этих компонент. Спасибо большое. подробнее

Показать сообщение отдельно
Shank
0 / 0 / 0
Регистрация: 17.05.2013
Сообщений: 14
04.06.2013, 12:36     составить блок-схемы по коду
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <string>
#include <cmath>
#include <sstream>
 
// Класс "Статистическая характеристика"
class StatisticMethod
{
public:
    // конструктор по умолчанию
    StatisticMethod() :
      data(NULL), size_(0u)
      {
      }
 
      // конструктор с параметрами
      StatisticMethod(const double * const array, const unsigned int size) :
      data(NULL), size_(size)
      {
          setArray(array, size);
      }
 
      // установить массив чисел
      void setArray(const double * const array, const unsigned int size)
      {
          clear();
 
          size_ = size;
          data = new double[size_];
          memcpy(data, array, sizeof(double) * size_);
      }
 
      // получение размера массива чисел
      unsigned int size() const
      {
          return size_;
      }
 
      // очищение массива чисел
      void clear()
      {
          if (data)
          {
              size_ = 0u;
              delete[]data;
              data = NULL;
          }
      }
 
      // деструктор
      virtual ~StatisticMethod()
      {
          clear();
      }
 
      // число виртуальный метод вычисления характеристики
      // (данный метод будет переопределен в наследниках)
      virtual double calculate() const = 0;
 
      // получение имени характеристики
      virtual std::string getName() const = 0;
 
protected:
    // массив чисел
    double * data;
    // размерность массива чисел
    unsigned int size_;
};
 
// Класс "Момент k-порядка"
class KStartMoment :
    public StatisticMethod
{
public:
    // конструктор класса
    KStartMoment(const unsigned int k) :
      StatisticMethod(), k(k)
      {
      }
 
      // конструктор с данными
      KStartMoment(const unsigned int k,
          const double * const array,
          const unsigned int size) :
      StatisticMethod(array, size), k(k)
      {
      }
 
      // переопределение метода вычисления характеристики
      virtual double calculate() const
      {
          double result = 0.0;
          double k_ = static_cast<double>(k);
 
          for (unsigned int i = 0u; i < size_; ++i)
              result += std::pow(data[i], k_);
          result /= static_cast<double>(size_);
 
          return result;
      }
 
      // переопределение метод получения имени характеристики
      virtual std::string getName() const
      {
          std::stringstream stream(std::stringstream::in | std::stringstream::out);
          std::string kRepr;
 
          stream << k;
          stream >> kRepr;
 
          return "Момент " + kRepr + " порядка";
      }
 
      // деструктор
      virtual ~KStartMoment()
      {
      }
 
private:
    // порядок момента
    unsigned int k;
};
 
// Класс "Центральный момент k-ого порядка"
class KCentralMoment :
    public KStartMoment
{
public:
    // конструктор
    KCentralMoment(const unsigned int k) :
      KStartMoment(1u), pk(k)
      {
      }
 
      // конструктор с параметрами
      KCentralMoment(const unsigned int k,
          const double * const array,
          const unsigned int size) :
      KStartMoment(1u, array, size), pk(k)
      {
      }
 
      // переопределение метода вычисления характеристики
      virtual double calculate() const
      {
          double KStartMoment = KStartMoment::calculate();
          double result = 0.0, k_ = static_cast<double>(pk);
 
          for (unsigned int i = 0u; i < size_; ++i)
              result += std::pow(data[i] - KStartMoment, k_);
          result /= static_cast<double>(size_);
 
          return result;
      }
 
      // переопределение метода получения имени характеристики
      virtual std::string getName() const
      {
          std::stringstream stream(std::stringstream::in | std::stringstream::out);
          std::string kRepr;
 
          stream << pk;
          stream >> kRepr;
 
          return "Центральный момент " + kRepr + " порядка";
      }
 
      // деструктор
      virtual ~KCentralMoment()
      {
      }
 
private:
    // порядок момента
    unsigned int pk;
};
 
// Класс "Среднее квадратическое отклонение"
class StandartDeviation :
    public KCentralMoment
{
public:
    // конструктор
    StandartDeviation() :
      KCentralMoment(2u)
      {
      }
 
      // конструктор с параметрами
      StandartDeviation(const double * const data,
          const unsigned int size) :
      KCentralMoment(2u, data, size)
      {
      }
 
      // переопределение метода вычисление характеристики
      virtual double calculate() const
      {
          return std::pow(KCentralMoment::calculate(), 0.5);
      }
 
      // переопределение метода определения имени характеристики
      virtual std::string getName() const
      {
          return "Среднее квадратическое отклонение";
      }
 
      // Деструктор
      virtual ~StandartDeviation()
      {
      }
};
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 09:00. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru