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

2. В одномерном массиве найти среднее арифметическое для элементов, расположенных между максимальным и минимальным - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Задача на теорию автоматов http://www.cyberforum.ru/cpp-beginners/thread699504.html
Условие во вложение. Не совсем понимаю алгоритм. Есть какие-нибудь идеи?
C++ из паскаля в C++ 3)Даны два действитьельных числа. Заменить первое число нулем, если оно меньше или равно второму и оставить числа без изменения в противном случае. Program dvecifri Var a, b: real; begin Writeln('Vvedite A:'); Readln(A); Writeln('Vvedite B:'); Readln(B); if A <= B then A := 0; http://www.cyberforum.ru/cpp-beginners/thread699493.html
Устранить из строки все заданные группы букв C++
Создать функцию обработки строки, который может содержать любое количество произвольных символов. Устранить все заданные группы букв, например: ТИП
C++ Расписание автобусов или как пользоваться time.h
Здравтвуйте. Есть задача: "В справочной автовокзала хранится расписание движения автобусов. Для каждого рейса указаны его номер, тип автобуса, пункт назначения, время отправления и прибытия. Вывести информацию о рейсах, которыми можно воспользоваться для прибытия в пункт назначения раньше заданного времени." Вот код(рабочий):
C++ Расписание автобусов или как пользоваться time.h http://www.cyberforum.ru/cpp-beginners/thread699478.html
Здравтвуйте. Есть задача: "В справочной автовокзала хранится расписание движения автобусов. Для каждого рейса указаны его номер, тип автобуса, пункт назначения, время отправления и прибытия. Вывести информацию о рейсах, которыми можно воспользоваться для прибытия в пункт назначения раньше заданного времени." Вот код(рабочий):
C++ Вычислить значение средних величин для заданной выборки x1,x2,x3.,xn помогите составить программу, которая для заданной выборки x1,x2,x3...,xn вычисляет значение средних величин. Вот задание: Составьте программу, которая для заданной выборки {x}_{1},\ {x}_{2},\ ...,\ {x}_{N} вычисляет значение средних величин: среднее арифметическое {S}_{1} = \frac{{x}_{1}+{x}_{2}+...+{x}_{n}}{n}, среднее геометрическое {S}_{2}=\sqrt{{x}_{1}\cdot {x}_{2}\cdot ... \cdot... подробнее

Показать сообщение отдельно
lemegeton
 Аватар для lemegeton
2913 / 1342 / 133
Регистрация: 29.11.2010
Сообщений: 2,720
16.11.2012, 18:43     2. В одномерном массиве найти среднее арифметическое для элементов, расположенных между максимальным и минимальным
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
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
#include <math.h>
 
int main(int argc, char *argv[]) {
  // задание зерна для генератора случайных чисел
  srand(time(0));
  // размер
  const size_t size = 10;
  // массив
  double *data = (double*)malloc(size * sizeof(double));
 
  // массив заполняется и выводится
  for (double *i = data; i != data + size; ++i)
    printf("%.1f ", *i = (rand() % 1000) / 10.);
  printf("\n");
  
  // поиск мимнимума и максимума в массиве
  double *min, *max;
  min = max = data;
  for (double *i = data; i != data + size; ++i) {
    if (*i >= *max) max = i; // последний максимальный
    if (*i < *min) min = i;  // первый минимальный
  }
  
  printf("Maximum: %.1f; Minimum: %.1f; %d number(s) in between;\n", *max, *min, abs(max - min));
  
  // если между минимумом и максимумом нет элементов,
  if (abs(max - min) < 2) {
    // ответ -- 0
    printf("Max too near min. Answer is 0.");
    return 0;
  }
  // если минимальный элемент стоит после максимального
  if (min > max) {
    // поменять их местами
    double *tmp = min;
    min = max;
    max = tmp;
  }
  
  // накопитель для среднего арфиметического
  double average = 0.;
  // от минимального до максимального элемента не включительно
  for (double *i = min + 1; i != max; ++i) {
    printf("%.1f ", *i);
    average += *i; // накапливается сумма
  }
  // выводится ответ
  printf("\nAverage: %.1f\n", average / (max - min - 1));
  
  // освобождается память под массив
  free(data);
  return 0;
}
 
Текущее время: 17:54. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru