Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.74/47: Рейтинг темы: голосов - 47, средняя оценка - 4.74
1 / 1 / 1
Регистрация: 25.10.2017
Сообщений: 155

В каждой строке матрицы найти количество элементов, меньших среднего арифметического всех элементов этой строки

01.11.2017, 23:54. Показов 10015. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Есть такое задание:
Дана матрица размера M×N. В каждой ее строке найти количество элементов, меньших среднего арифметического всех элементов этой строки.

Я написал вот такой код:
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
class Program
    {
        static void Main(string[] args)
        {
            Console.Write("Введите количество столбоцов:");
            int Stolb = Convert.ToInt32(Console.ReadLine());
            Console.Write("Введите количество строк:");
            int Strok = Convert.ToInt32(Console.ReadLine());
            double schet,s,sr;
            Random rnd = new Random();
            int[,] A = new int[Strok, Stolb];
            Console.WriteLine();
            
            for (int i = 0; i < Strok; i++)
            {
                for (int j = 0; j < Stolb; j++)
                {
                    A[i, j] = rnd.Next(1, 10);
                    Console.Write("{0}\t", A[i, j]);
                }
                Console.WriteLine();
            }
            Console.WriteLine();
            for (int i = 0; i < Strok; i++)
            {
                s = 0;
                sr = 1;
                schet = 0;
                
                for (int j = 0; j < Stolb; j++)
                {
                    s = s + A[i, j];
                    sr = s / Stolb;
                    if (sr>=A[i,j])
                    {
                        
                        schet++;
                        
                    }
                }
               
                Console.WriteLine("Сумма элементов : " + s);
                Console.WriteLine("Серднее арефметическое : "+sr);
                Console.WriteLine("Количество элементов строки меньше среднего арефметического этой строки : " + schet);
            }
            Console.WriteLine();
            Console.ReadKey();
        }
    }
Сами видите считает среднее арифметическое правильно. Но у меня не правильно считает количество элементов в строке меньших ср.арифм. мои догадки склоняются к тому, что он не правильно сравнивает, т.к. сравниваются целые числа и дробные. Т.е. разные типы данных. Как мне это дело исправить?(
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.11.2017, 23:54
Ответы с готовыми решениями:

В каждой строке матрицы найти количество элементов,меньших среднего арифметического всех элементов этой строки
2) Дана матрица размера MxN. В каждой ее строке найти количество элементов,меньших среднего арифметического всех элементов этой строки. ...

В каждой строке матрицы найти количество элементов, меньших среднего арифметического всех элементов этой строки.
Дана матрица размера M  N. В каждой ее строке найти количество элементов, меньших среднего арифметического всех элементов этой строки. ...

В каждой строке матрицы найти количество элементов, меньших среднего арифметического всех элементов этой строки
Дана матрица размера M  N. В каждой ее строке найти количество элементов, меньших среднего арифметического всех элементов этой строки.

4
44 / 45 / 41
Регистрация: 28.06.2017
Сообщений: 133
02.11.2017, 00:40
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
using System;
class Program
{
    static void Main(string[] args)
    {
        Console.SetWindowSize(80, 60);
        Console.Write("Введите количество столбоцов : ");
        int column = Convert.ToInt32(Console.ReadLine());
        Console.Write("Введите количество строк : ");
        int row = Convert.ToInt32(Console.ReadLine());
        Random rnd = new Random();
        int[,] array = new int[column, row];
        Console.WriteLine();
 
        for (int j = 0; j < row; j++)
        {
            for (int i = 0; i < column; i++)
            {
                array[i, j] = rnd.Next(1, 100);
                Console.Write("{0,-4}", array[i, j]);
            }
            Console.WriteLine();
        }
        Console.WriteLine();
        double sum; //сумма элементов строки
        double average; // ср. арифм. строки
        int smallerElem; // кол. элементов менее ср. арифм.
        for (int j = 0; j < row; j++)
        {
            average = 0;
            sum = 0;
            smallerElem = 0;
            for (int i = 0; i < column; i++)
            {
                sum += array[i, j];
            }
            average = (double)sum / column;
            for (int i = 0; i < column; i++)
            {
                if (array[i, j] < average)
                {
                    smallerElem++;
                }
            }
            Console.WriteLine("Сумма элементов : {0}", sum);
            Console.WriteLine("Серднее арефметическое : {0:0.00}", average);
            Console.WriteLine("Кол-во элементов строки значеним менее среднего арифметического этой строки : {0} ", smallerElem);
        }
        Console.ReadKey();
    }
}
0
97 / 98 / 58
Регистрация: 29.09.2016
Сообщений: 410
02.11.2017, 01:02
Вот твой же код, тебе просто нужно сделать два вложенных цикла, в одном в начале отдельно вся строка просуммируется , а во втором уже средн.арифм и условие .
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
for (int i = 0; i < Strok; i++)
            {
                s = 0;
                sr = 1;
                schet = 0;
 
                for (int j = 0; j < Stolb; j++)
                {
                    s = s + A[i, j];
                }
                sr = s / Stolb;
                for(int j = 0; j < Stolb; j++)
                {
                    
                    if (sr >= A[i, j])
                    {
 
                        schet++;
 
                    }
                }
                Console.WriteLine("Сумма элементов : " + s);
                Console.WriteLine("Серднее арефметическое : " + sr);
                Console.WriteLine("Количество элементов строки меньше среднего арефметического этой строки : " + schet);
            }
1
1 / 1 / 1
Регистрация: 25.10.2017
Сообщений: 155
02.11.2017, 01:17  [ТС]
Большое спасибо, но мне очень интересно, что было у меня не так???
Уж очень сильно хочу понять, что я не так сделал.?

Добавлено через 2 минуты
Вопрос, а почему нельзя всё делать в одном? Обязательно разбивать на два??(
0
97 / 98 / 58
Регистрация: 29.09.2016
Сообщений: 410
02.11.2017, 01:23
Лучший ответ Сообщение было отмечено Goshaa как решение

Решение

Goshaa, потому что в одном цикле, как только ты просуммируешь все элементы строки и выведешь срд.арифметическую этой же строки, итерации закончатся и ты вылетишь из цикла. И не сможешь сравнить эти элементы с средн.ариф.значением.А тебе надо аж с самого начала снова пробежаться по всем элементам строки. Ты безусловно производишь сравнения, но это сравнение элемента не со срдн.арифм.значнием.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.11.2017, 01:23
Помогаю со студенческими работами здесь

Дана матрица размера M х N. В каждой ее строке найти количество элементов, меньших среднего арифметического всех элементов этой строки
Помогите пожалуйста записать задачу в языке программирования Java. var a:array of integer; i,j,m,n,S:integer; b:array of real; ...

В каждой строке и столбце найти количество элементов, больших и меньших среднего арифметического всех элементов этой строки и столбца.
решите пожалуйста задачу, очень надо, у самой не получается.. задача: Дана матрица размера 5 х 10. Элементы массива вводятся с...

Дана матрица размера M x N в каждой ее строке найти количество элементов меньших среднего арифметического всех элементов этой строки
Помогите пожалуйста :)

В каждой строке матрицы найти количество элементов, больших среднего арифметического всех элементов этой строки
2) Дана матрица размера 6 х 9. В каждой строке найти количество элементов, больших среднего арифметического всех элементов этой строки.

В каждой строке матрицы найти количество элементов, больших среднего арифметического всех элементов этой строки
Дана матрица размера 5 x 10. В каждой строке найти количество элементов, больших среднего арифметического всех элементов этой строки. +...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru