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

Нахождение среднего балла - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.78
pinksacura
0 / 0 / 0
Регистрация: 28.10.2010
Сообщений: 14
12.01.2011, 18:03     Нахождение среднего балла #1
Помогите пожалуйста с решением задачки

Выступление спортсмена оценивают N арбитров (N>=3). Во избежании необъективности судейства оценки, отличающиеся от среднего балла более, чем на 0.3 в любую сторону, отбрасывают и находят среднее из оставшихся баллов. Написать программу, вычисляющую итоговую оценку спортсмена, и проверить ее для массива оценок {5.5, 6.0, 5.6, 5.6, 5.2, 5.7, 5.4, 5.5}

Большое спасибо!
А то я даже не знаю с чего начать(
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.01.2011, 18:03     Нахождение среднего балла
Посмотрите здесь:

Вычисление среднего балла C++
Составить программу для вывода среднего балла C++
Подсчет среднего балла каждой группы C++
C++ Составить программу для вычисления среднего балла студентов
Структура. Вывести информацию по студентам в порядке уменьшения среднего балла C++
Выведите фамилии и имена учащихся в порядке убывания их среднего балла C++
C++ Выведите фамилии и имена студентов в порядке убывания их среднего балла
Упорядочить список студентов по возрастанию среднего балла C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
lemegeton
 Аватар для lemegeton
2910 / 1339 / 133
Регистрация: 29.11.2010
Сообщений: 2,720
12.01.2011, 18:48     Нахождение среднего балла #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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/*
  Выступление спортсмена оценивают N арбитров (N>=3). Во избежании
  необъективности судейства оценки, отличающиеся от среднего балла
  более, чем на 0.3 в любую сторону, отбрасывают и находят среднее
  из оставшихся баллов. Написать программу, вычисляющую итоговую оценку
  спортсмена, и проверить ее для массива оценок
  {5.5, 6.0, 5.6, 5.6, 5.2, 5.7, 5.4, 5.5}
*/
 
#include <cstdio>
#include <cstdlib>
#include <ctime>
#include <cstddef>
#include <cmath>
 
float FindAverageMark(float *marks, const size_t &marks_count,
                       const float &deviation = 0.30) {
  float *temporary_marks = new float[marks_count];
  for (int i = 0; i < marks_count; ++i)
    temporary_marks[i] = marks[i];
 
  size_t wrong_marks_count = 0;
  bool wrong_marks_count_changed;
  float marks_average;
  do {
    wrong_marks_count_changed = false;
    marks_average = 0.0;
    for (int i = 0; i < marks_count; ++i)
      if (temporary_marks[i] > -1)
        marks_average += temporary_marks[i];
    marks_average /= marks_count - wrong_marks_count;
    for (int i = 0; i < marks_count; ++i)
      if (temporary_marks[i] > -1 && fabs(temporary_marks[i]
          - marks_average) > deviation) {
        temporary_marks[i] = -1;
        wrong_marks_count_changed = true;
        ++wrong_marks_count;
      }
  } while (wrong_marks_count_changed && (marks_count != wrong_marks_count));
  return (marks_count == wrong_marks_count) ? -1 : marks_average;
}
 
int main(int argc, char *argv[]) {
  srand(time(NULL));
 
  printf("Random marks:\n");
  float *marks;
  size_t marks_count = 10 + rand() % 5;
  marks = new float[marks_count];
  for (int i = 0; i < marks_count; ++i)
    printf("%f ", marks[i] = 5 + rand() % 3 + (rand() % 10) / 10.);
  printf("\n");
 
  float average_mark = FindAverageMark(marks, marks_count, 0.3);
  if (average_mark < 0)
    printf("Deviation is too high. No reliable marks.\n");
  else
    printf("Average mark: %f.\n", average_mark);
  delete [] marks;
 
  printf("Given marks:\n");
  float given_marks[] = {5.5, 6.0, 5.6, 5.6, 5.2, 5.7, 5.4, 5.5};
  for (int i = 0; i < 8; ++i)
    printf("%f ", given_marks[i]);
  printf("\n");
  average_mark = FindAverageMark(given_marks, 8, 0.3);
  if (average_mark < 0)
    printf("Deviation is too high. No reliable marks.\n");
  else
    printf("Average mark: %f.\n", average_mark);
 
  return 0;
}
pinksacura
0 / 0 / 0
Регистрация: 28.10.2010
Сообщений: 14
13.01.2011, 00:13  [ТС]     Нахождение среднего балла #3
ответ не знаю(
это задачи к экзамену.

спасибо большое
Yandex
Объявления
13.01.2011, 00:13     Нахождение среднего балла
Ответ Создать тему
Опции темы

Текущее время: 00:41. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru