С Новым годом! Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/21: Рейтинг темы: голосов - 21, средняя оценка - 4.57
3 / 3 / 1
Регистрация: 13.12.2011
Сообщений: 70
1

Определить лучшую по средней оценке группу

03.01.2012, 23:54. Показов 3790. Ответов 9
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Три группы студентов, в каждой из которых 20 человек, в сессию сдавали по 3 экзамена. Сведения об оценках каждой группы хранятся в двумерных массивах. Определить лучшую по средней оценке группу.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.01.2012, 23:54
Ответы с готовыми решениями:

Задача о средней оценке
Здравствуйте. Помогите пожалуйста решить задачу: В соревнованиях по фигурному катанию N судей...

Определить лучшую по средней оценке группу
Три группы студентов, по 10 человек в каждой группе, сдавали в сессию по 3 экзамена. Сведения об...

Определить лучшую по средней оценке группу
Три группы студентов, по 10 человек в каждой группе, сдавали в сессию по 3 экзамена. Сведения об...

Двумерные массивы: определить лучшую по средней оценке группу
Три группы студентов, в каждой из которых 20 человек, в сессию сдавали по 3 экзамена. Сведения об...

9
24 / 24 / 4
Регистрация: 07.02.2011
Сообщений: 163
04.01.2012, 13:22 2
Для первой группы:
Считаешь средний балл по каждому студенту (на основе оценок за экзамены - сумма всех оценок для каждого из студентов/3), потом на основе средних баллов по каждому студенту считаешь средний балл по группе (сумма всех средних баллов студентов за экзамены/20).

Для второй и третьей то же самое. Далее сравниваешь три получившиеся оценки между собой.
Вроде так
0
3 / 3 / 1
Регистрация: 13.12.2011
Сообщений: 70
04.01.2012, 15:40  [ТС] 3
спасибо, конечно, большое, но было бы не плохо если бы ещё и программу написали. С одномерными массивами всё понятно, а тут ерунда какая то
0
80 / 78 / 10
Регистрация: 29.12.2011
Сообщений: 183
04.01.2012, 16:40 4
Вот код
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
//Три группы студентов, в каждой из которых 20 человек, в сессию сдавали по 3 экзамена. 
//Сведения об оценках каждой группы хранятся в двумерных массивах. Определить лучшую по 
//средней оценке группу. 
namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            int[,] students1 = new int[20, 3];
            int[,] students2 = new int[20, 3];
            int[,] students3 = new int[20, 3];
            long sred=0;
            Random rnd = new Random(DateTime.UtcNow.Millisecond);
            // Заполняем 1 массив
            for (int i = 0; i < students1.GetLength(0); i++)
            {
                for (int j = 0; j < students1.GetLength(1); j++)
                {
                    students1[i, j] = rnd.Next(3, 6);
                }
            }
            // Заполняем 2 массив
            for (int i = 0; i < students2.GetLength(0); i++)
            {
                for (int j = 0; j < students2.GetLength(1); j++)
                {
                    students2[i, j] = rnd.Next(3, 6);
                }
            }
            // Заполняем 3 массив
            for (int i = 0; i < students3.GetLength(0); i++)
            {
                for (int j = 0; j < students3.GetLength(1); j++)
                {
                    students3[i, j] = rnd.Next(3, 6);
                }
            }
 
            double [] GroupSred = new double[3]; // массив оценок каждой группы
            // Считаем оценки по первой группе
            for (int i = 0; i < students1.GetLength(0); i++)
            {
                sred = 0;
                for (int j = 0; j < students1.GetLength(1); j++)
                {
                    sred += students1[i, j];// Суммируем оценки за экзамены
                }
                GroupSred[0] += sred / 3.0; // Средняя ученика по экзаменам
            }
            GroupSred[0] = GroupSred[0] / 20.0;// Средняя всей группы
 
            // Считаем оценки по второй группе
            for (int i = 0; i < students2.GetLength(0); i++)
            {
                sred = 0;
                for (int j = 0; j < students2.GetLength(1); j++)
                {
                    sred += students2[i, j];// Суммируем оценки за экзамены
                }
                GroupSred[1] += sred / 3.0;// Средняя ученика по экзаменам
            }
            GroupSred[1] = GroupSred[1] / 20.0;// Средняя всей группы
 
            // Считаем оценки по третьей группе
            for (int i = 0; i < students3.GetLength(0); i++)
            {
                sred = 0;
                for (int j = 0; j < students3.GetLength(1); j++)
                {
                    sred += students3[i, j]; // Суммируем оценки за экзамены
                }
                GroupSred[2] += sred / 3.0;// Средняя ученика по экзаменам
            }
            GroupSred[2] = GroupSred[2] / 20.0;// Средняя всей группы
 
            //выводим на экран без сортировки
            for (int i = 0; i < GroupSred.Length; i++)
            {
                if (GroupSred.Max() == GroupSred[i])
                Console.WriteLine("ЛУЧШАЯ ГРУППА {0} \t{1}\n", i+1, GroupSred[i]);
            }
 
            for (int i = 0; i < GroupSred.Length; i++)
            {
                    Console.WriteLine("Группа {0} \t{1}", i+1, GroupSred[i]);
            }
        }
    }
}


Можно реализовать метод, который бы вычислял среднюю по каждому массиву и там зарыть большую часть этого кода. И еще метод для заполнения массивов. Только нужно небольшой класс накидать и там спрятать все это. Будет опрятно.
1
30 / 30 / 4
Регистрация: 04.01.2012
Сообщений: 135
04.01.2012, 16:45 5
Как-то так может?
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
 static void Main(string[] args)
        {
            //сделал по 6 студентов. каждая строчка оценка студента за каждый экзамен.
            int[,] group1 = { { 3, 4, 3 }, { 4, 4, 4 }, { 5, 3, 3 }, { 3, 4, 2 }, { 4, 3, 4 }, { 4, 4, 5 } }; 
            int[,] group2 = { { 5, 5, 5 }, { 4, 4, 4 }, { 3, 3, 3 }, { 3, 4, 2 }, { 4, 5, 4 }, { 2, 4, 5 } };
            int[,] group3 = { { 3, 2, 3 }, { 4, 2, 4 }, { 4, 3, 3 }, { 3, 4, 4 }, { 4, 4, 4 }, { 3, 4, 3 } };
            double sr1 = 0;
            double sr2 = 0;
            double sr3 = 0;
            for (int i = 0; i < 6; i++)
            {
                for (int j = 0; j < 3; j++)
                {
                    sr1 = sr1 + group1[i, j];
                }
            }
            for (int i = 0; i < 6; i++)
            {
                for (int j = 0; j < 3; j++)
                {
                    sr2 = sr2 + group2[i, j];
                }
            }
            for (int i = 0; i < 6; i++)
            {
                for (int j = 0; j < 3; j++)
                {
                    sr3 = sr3 + group3[i, j];
                }
            }
 
            Console.WriteLine(sr1 / 18); //18 = количество студентов умножить на количество экзаменов
            Console.WriteLine(sr2 / 18);
            Console.WriteLine(sr3 / 18);
        }
0
3 / 3 / 1
Регистрация: 13.12.2011
Сообщений: 70
04.01.2012, 17:44  [ТС] 6
Спасибо) Возьму для примера 1 код, что нибудь сделаю... Мне просто ещё в общем виде нужно, ну это я уже и сам справлюсь)))
0
80 / 78 / 10
Регистрация: 29.12.2011
Сообщений: 183
04.01.2012, 19:01 7
Цитата Сообщение от ibmpc Посмотреть сообщение
Можно реализовать метод, который бы вычислял среднюю по каждому массиву и там зарыть большую часть этого кода. И еще метод для заполнения массивов. Только нужно небольшой класс накидать и там спрятать все это. Будет опрятно.
Кстати когда писал сей коммент была идея реализовать расширения для двухмерных массивов. Оказывается вполне прокатывает.
1
3 / 3 / 1
Регистрация: 13.12.2011
Сообщений: 70
05.01.2012, 02:22  [ТС] 8
Цитата Сообщение от ibmpc Посмотреть сообщение
Кстати когда писал сей коммент была идея реализовать расширения для двухмерных массивов. Оказывается вполне прокатывает.
не, я такого вообще незнаю

Добавлено через 5 часов 45 минут
Вот, переделал первый код, громоздко, но работает прекрасно)) спасибо

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
Console.WriteLine("Заполните данные для ПЕРВОЙ группы:");
                    Console.Write("Студент {0}-ый, оценка за {1} экзамен: ", i + 1, j + 1);
                    students1[i, j] = int.Parse(Console.ReadLine());
                    Console.Clear();
                }
            for (int i = 0; i < n; i++)
                for (int j = 0; j < N; j++)
                {
                    Console.WriteLine("Заполните данные для ВТОРОЙ группы:");
                    Console.Write("Студент {0}-ый, оценка за {1} экзамен: ", i + 1, j + 1);
                    students2[i, j] = int.Parse(Console.ReadLine());
                    Console.Clear();
                }
            for (int i = 0; i < n; i++)
                for (int j = 0; j < N; j++)
                {
                    Console.WriteLine("Заполните данные для ТРЕТЬЕЙ группы:");
                    Console.Write("Студент {0}-ый, оценка за {1} экзамен: ", i + 1, j + 1);
                    students3[i, j] = int.Parse(Console.ReadLine());
                    Console.Clear();
                }
            double[] GroupSred = new double[n*N];
            for (int i = 0; i < n; i++)
            {
                for (int j = 0; j < N; j++)
                {
                    sred1 += students1[i, j];
                }
            }
            GroupSred[0] = sred1 / (n*N);
            for (int i = 0; i < n; i++)
            {
                for (int j = 0; j < N; j++)
                {
                    sred2 += students2[i, j];
                }
            }
            GroupSred[1] = sred2 / (n * N);
            for (int i = 0; i < n; i++)
            {
                for (int j = 0; j < N; j++)
                {
                    sred3 += students3[i, j];
                }
            }
            GroupSred[2] = sred3 / (n * N);
            for (int i = 0; i < 3; i++)
            {
                Console.WriteLine("Группа {0} - средняя оценка: {1:.####}", i + 1, GroupSred[i]);
            }
            for (int i = 0; i < 3; i++)
            {
                if (GroupSred.Max() == GroupSred[i])
                    Console.WriteLine("Лучшая группа {0} - средняя оценка: {1:.####}\n", i + 1, GroupSred[i]);
            }
            Console.ReadLine();
0
80 / 78 / 10
Регистрация: 29.12.2011
Сообщений: 183
05.01.2012, 19:51 9
Компактный вариант с использованием библиотечки, можно просто еще один cs фаил в проект добавить.
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Extension.IntArray;
//Три группы студентов, в каждой из которых 20 человек, в сессию сдавали по 3 экзамена. 
//Сведения об оценках каждой группы хранятся в двумерных массивах. Определить лучшую по 
//средней оценке группу. 
namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            int[,] students1 = new int[20, 3];
            int[,] students2 = new int[20, 3];
            int[,] students3 = new int[25, 2];// Кол-во студентов и оценок может быть любым.
 
            // Заполняем 1 массив
            students1.FillRnd(3, 6);
            // Заполняем 2 массив
            students2.FillRnd(3, 6);
            // Заполняем 3 массив
            students3.FillRnd(3, 6);
            //Вывод на консоль
            Console.WriteLine("Группа 1: \t{0} балла.", Math.Round(students1.SredArif(),2) );
            Console.WriteLine("Группа 2: \t{0} балла.", Math.Round(students2.SredArif(),2));
            Console.WriteLine("Группа 3: \t{0} балла.", Math.Round(students3.SredArif(),2));
 
            Console.WriteLine("\nЛучшая оценка: \t{0} балла.",
                (new double[] { Math.Round(students1.SredArif(),2), Math.Round(students2.SredArif(),2)
                    , Math.Round(students3.SredArif(),2) }).Max<double>()                
                );
        }
    }
}




Код библиотечки (реализация расширений)
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
//Библиотека  расширений созданная для приминения с двухмерными массивами int[,]
//Содержит расширения для заполнения всего массива случ. числами на основе Random.Next
//и заполнения одним числом.
// Расширение для вычисления сред. ариф. чисел в массиве создано 
// для вычисления лучшего студента.(Первая размерность их кол-во, вторая - оценки) 
namespace Extension.IntArray
{
    public static class ExeptionForArray
    {
        static Random rnd = new Random(DateTime.UtcNow.Millisecond);
        /// <summary>Заполняет массив случайными числами на основе Random.Next.</summary>
        public static void FillRnd(this int[,] value)
        {
            if (value == null) return;
            for (int i = 0; i < value.GetLength(0); i++)
            {
                for (int j = 0; j < value.GetLength(1); j++)
                {
                    value[i, j] = rnd.Next();
                }
            }
        }
        /// <summary>Заполняет массив случайными числами на основе Random.Next.</summary>
        /// <param name="UpBound">Верхний не включенный придел</param>
        public static void FillRnd(this int[,] value,int UpBound)
        {
            if (value == null) return;
            for (int i = 0; i < value.GetLength(0); i++)
            {
                for (int j = 0; j < value.GetLength(1); j++)
                {
                    value[i, j] = rnd.Next(UpBound);
                } 
            }
        }
        /// <summary>Заполняет массив случайными числами на основе Random.Next.</summary>
        /// <param name="DownBound">Нижний включенный придел.</param>
        /// <param name="UpBound">Верхний не включенный придел.</param>
        public static void FillRnd(this int[,] value, int DownBound,int UpBound)
        {
            if (value == null) return;
            for (int i = 0; i < value.GetLength(0); i++)
            {
                for (int j = 0; j < value.GetLength(1); j++)
                {
                    value[i, j] = rnd.Next(DownBound, UpBound);
                }
            }
        }
        /// <summary>Заполняет весь массив одним значением</summary>
        /// <param name="digit">Целое число, которым заполняется массив.</param>
        public static void FillDigit(this int[,] value, int digit)
        {
            if (value == null) return;
            for (int i = 0; i < value.GetLength(0); i++)
            {
                for (int j = 0; j < value.GetLength(1); j++)
                {
                    value[i, j] = digit;
                }
            }
        }
        /// <summary>Вычисляет сред. ариф по определенной формуле.</summary>
        /// <returns>Возвращает среднее арифмитическое вычисленное по след формуле: 
        /// сумма сред. ариф. вторых размерностей деленное на кол-во первых размерностей.</returns>
        public static double SredArif(this int[,] value)
        {
            if (value == null) return 0;
            int sred;
            double sum=0;
            for (int i = 0; i < value.GetLength(0); i++)
            {
                sred = 0;
                for (int j = 0; j < value.GetLength(1); j++)
                {
                    sred += value[i, j];// Суммируем оценки за экзамены
                }
                sum += (double)sred / (double)value.GetLength(1); // Средняя ученика по экзаменам
            }
            return sum / (double)value.GetLength(0);// Средняя всей группы
        }
    }
}
Вложения
Тип файла: zip students.zip (35.3 Кб, 13 просмотров)
0
80 / 78 / 10
Регистрация: 29.12.2011
Сообщений: 183
05.01.2012, 19:52 10
Это был вариант для моего кода. Можно изменить код автора темы - засунуть расширения в еще один фаил cs в проекте. И код станет компактнее и легче для восприятия.
1
05.01.2012, 19:52
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
05.01.2012, 19:52
Помогаю со студенческими работами здесь

Три группы студентов. Определить лучшую по средней оценке группу.
Задача на Компонент StringGrid: Три группы студентов, в каждой из которых 20 человек, в сессию...

Определить лучшую по среднему баллу группу
Три группы студентов, в каждой из которых по 20 человек, в сессию сдавали по три экзамена....

Определить, содержит ли заданный массив группы элементов, расположенные в порядке убывания их значений. Если да, то определить группу наименьшей длины
Помогите с прграммой .Нужно написать программу на С++ с использован им масива Определить,...

Определить длину средней линии трапеции
Определить длину средней линии трапеции АВСД, если известны точки А(3, -1, 2), В(1,2,3), С(-3,4,6),...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Блоги программистов
Как перейти с Options API на Composition API в Vue.js
BasicMan 06.01.2025
Почему переход на Composition API актуален В мире современной веб-разработки фреймворк Vue. js продолжает эволюционировать, предлагая разработчикам все более совершенные инструменты для создания. . .
Архитектура современных процессоров
inter-admin 06.01.2025
Процессор (центральный процессор, ЦП) является основным вычислительным устройством компьютера, которое выполняет обработку данных и управляет работой всех остальных компонентов системы. Архитектура. . .
История создания реляционной модели баз данных, правила Кодда
Programming 06.01.2025
Предпосылки создания реляционной модели В конце 1960-х годов компьютерная индустрия столкнулась с серьезными проблемами в области управления данными. Существовавшие на тот момент модели данных -. . .
Полезные поделки на Arduino, которые можно сделать самому
raxper 06.01.2025
Arduino как платформа для творчества Arduino представляет собой удивительную платформу для технического творчества, которая открывает безграничные возможности для создания уникальных проектов. Эта. . .
Подборка решений задач на Python
IT_Exp 06.01.2025
Целью данной подборки является предоставление возможности ознакомиться с различными задачами и их решениями на Python, что может быть полезно как для начинающих, так и для опытных программистов. . . .
С чего начать программировать микроконтроллер­­ы
raxper 06.01.2025
Введение в мир микроконтроллеров Микроконтроллеры стали неотъемлемой частью современного мира, окружая нас повсюду: от простых бытовых приборов до сложных промышленных систем. Эти маленькие. . .
Из чего собрать игровой компьютер
inter-admin 06.01.2025
Сборка игрового компьютера требует особого внимания к выбору комплектующих и их совместимости. Правильно собранный игровой ПК не только обеспечивает комфортный геймплей в современных играх, но и. . .
Обновление сайта www.historian.b­y
Reglage 05.01.2025
Обещал подвести итоги 2024 года для сайта. Однако начну с того, что изменилось за неделю. Добавил краткий урок по последовательности действий при анализе вредоносных файлов и значительно улучшил урок. . .
Как использовать GraphQL в C# с HotChocolate
Programming 05.01.2025
GraphQL — это современный подход к разработке API, который позволяет клиентам запрашивать только те данные, которые им необходимы. Это делает взаимодействие с API более гибким и эффективным по. . .
Модель полного двоичного сумматора с помощью логических операций (python)
AlexSky-coder 04.01.2025
def binSum(x:list, y:list): s=^y] p=x and y for i in range(1,len(x)): s. append((x^y)^p) p=(x and y)or(p and (x or y)) return s x=list() y=list()
Это мы не проходили, это нам не задавали...(аси­­­­­­­­­­­­­­хро­н­н­ы­й счётчик с управляющим сигналом задержки).
Hrethgir 04.01.2025
Асинхронный счётчик на сумматорах (шестиразрядный по числу диодов на плате, но наверное разрядов будет больше - восемь или шестнадцать, а диоды на старшие), так как триггеры прошли тестирование и. . .
Руководство по созданию бота для Телеграм на Python
IT_Exp 04.01.2025
Боты для Телеграм представляют собой автоматизированные программы, которые выполняют различные задачи, взаимодействуя с пользователями через интерфейс мессенджера. В данной статье мы рассмотрим,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru