Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/7: Рейтинг темы: голосов - 7, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 22.06.2022
Сообщений: 6

Написать функцию, подсчитывающую количество элементов в строке/столбце матрицы, равных заданному числу

22.06.2022, 05:10. Показов 1614. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написать функцию, подсчитывающую количество элементов в строке/столбце матрицы, равных заданному числу.

Прототип функции:
int lookingOut(const int arr[MAX_SIZE][MAX_SIZE], int N, int index, int identificator, int number);

param [in] arr - анализируемая матрица
param [in] N - размер матрицы [1, MAX_SIZE]
param [in] index - индекс анализирумой(го) строки/столбца [0, N-1]
param [in] identificator - признак того, что проверяется строка (1) / столбец (0)
param [in] number - число, наличие которого проверяется в строке/столбце
return - кол-во заданных чисел в строке/столбце

Что за "признак того, что проверяется строка (1) / столбец (0)" ?
И как гонять цикл чисто по одной строке или столбцу?
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.06.2022, 05:10
Ответы с готовыми решениями:

Найти количество элементов матрицы, равных заданному числу
Дана матрица В(n, n) и число k. Найти количество элементов матрицы, равных заданному числу k.

Найти количество элементов матрицы, равных заданному числу k
1. Дана матрица В(n, n) и число k. Найти количество элементов матрицы, равных заданному числу k.

Найти количество элементов матрицы, равных заданному числу k
Помогите составить программу. С формой, пожалуйста. Дана матрица В(n, n) и число k. Найти количество элементов матрицы, равных...

5
 Аватар для Аноним92
75 / 49 / 30
Регистрация: 14.10.2019
Сообщений: 147
22.06.2022, 06:22
Лучший ответ Сообщение было отмечено Medkit_li как решение

Решение

Если identificator = 1, number ищется в index-ной строке.
Если identificator = 0, number ищется в index-ном столбце.

Чтобы прогнать цикл по одной строке, нужно номер строки зафиксировать, а номер столбца менять

C++
1
2
3
for (int j = 0; j < N; j++)
  if (arr[index][j] == number)
     ...
1
0 / 0 / 0
Регистрация: 22.06.2022
Сообщений: 6
22.06.2022, 08:41  [ТС]
Аноним92, Огромное спасибо за объяснение.
Вроде все написал и появилась еще одна проблема, если я ставлю в конце main:
C++
1
 delete[]B;
то у меня вылетает отладка по 402 лайну.

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
#include <iostream>
using namespace std;
 
const int N = 4;
const int A = 3;
int index, identificator, number, s, result;
 
 
int lookingOut(int arr[A][N], const int N, int index, int identificator, int number)
{
    if (identificator == 0)
    {
        for (int j = 0; j < N; j++)
        {
            if (arr[index][j] == number)
            {
                s++;
            }
        }
    }
    if (identificator == 1)
    {
        for (int j = 0; j < A; j++)
        {
            if (arr[index][j] == number)
            {
                s++;
            }
        }
    }
    return s;
}
 
 
int main()
{
    setlocale( LC_ALL, "Rus" );
 
 
 
    int arr[A][N]{
    
        {2,10,15,36},
        {10,10,18,36},
        {98,21,32,32},
    };
 
    
    cout << "Выберети зону анализа (1 -строка, 0 -столбец) " << endl;
    cin >> identificator;
    
 
    while (identificator < 0 || identificator > 1)
    {
        cout << "Неверное значение! Диапазон значения от 0 до 1" << endl;
        cin >> identificator;
    };
 
    if (identificator == 0)
    {
        
        cout << "Введите адресс столбца" << endl;
        cin >>index;
        while (index < 0 || index > N  )
        {
            cout << "Неверное значение! Диапазон значения от 0 до "<< N << endl;
            cin >> index;
        };
     }
    else
    { 
        cout << "Введите адресс строки" << endl;
        cin >> index;
        
        while (index < 0 || index > A)
        {
            cout << "Неверное значение! Диапазон значения от 0 до " << A << endl;
            cin >> index;
        };
    
    }
    
    cout << "Введите число" << endl;
    cin >>number;
    
    
    cout << "Количество повторений:";
    result = lookingOut(arr, N, index, identificator, number);
    
    cout << result <<endl;
    
    system("pause");
}
0
Модератор
 Аватар для D1973
9929 / 6467 / 2457
Регистрация: 21.01.2014
Сообщений: 27,423
Записей в блоге: 3
22.06.2022, 09:08
Цитата Сообщение от Medkit_li Посмотреть сообщение
delete[]B;
Прежде, чем удалять что-то ненужное, надо сперва создать это что-то ненужное... А у Вас этого нет!
1
 Аватар для Аноним92
75 / 49 / 30
Регистрация: 14.10.2019
Сообщений: 147
22.06.2022, 09:11
Зачем вставляете эту строчку?
Цитата Сообщение от Medkit_li Посмотреть сообщение
delete[]B;
delete используется для освобождения памяти, выделенной операцией new.

У вас в коде:

1) нет ни одной операции new;
2) нет ни одного идентификатора B.

То есть целых 2 причины не вставлять эту строчку)
1
0 / 0 / 0
Регистрация: 22.06.2022
Сообщений: 6
22.06.2022, 09:43  [ТС]
Аноним92, D1973, Благодарю за помощь B это я ошибся там arr


Теперь точно полностью рабочий код, оставлю тут может кому пригодиться
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
#include <iostream>
using namespace std;
 
const int N = 4;
const int A = 3;
int index, identificator, number, s, result;
 
 
int lookingOut(int arr[A][N], const int N, int index, int identificator, int number)
{
    if (identificator == 0)
    {
        for (int j = 0; j < N+1; j++)
        {
            if (arr[j][index] == number)
            {
                s++;
            }
        }
    }
    if (identificator == 1)
    {
        for (int j = 0; j < A+1; j++)
        {
            if (arr[index][j] == number)
            {
                s++;
            }
        }
    }
    return s;
}
 
 
int main()
{
    setlocale( LC_ALL, "Rus" );
 
 
 
    int arr[A][N]{
    
        {2,10,15,36},
        {10,10,18,36},
        {98,21,32,32},
    };
 
    
    cout << "Выберети зону анализа (1 -строка, 0 -столбец) " << endl;
    cin >> identificator;
    
 
    while (identificator < 0 || identificator > 1)
    {
        cout << "Неверное значение! Диапазон значения от 0 до 1" << endl;
        cin >> identificator;
    };
 
    if (identificator == 0)
    {
        
        cout << "Введите адресс столбца" << endl;
        cin >>index;
        while (index < 0 || index > N-1  )
        {
            cout << "Неверное значение! Диапазон значения от 0 до "<< N-1 << endl;
            cin >> index;
        };
     }
    else
    { 
        cout << "Введите адресс строки" << endl;
        cin >> index;
        
        while (index < 0 || index > A-1)
        {
            cout << "Неверное значение! Диапазон значения от 0 до " << A-1 << endl;
            cin >> index;
        };
    
    }
    
    cout << "Введите число" << endl;
    cin >>number;
    
    
    cout << "Количество повторений:";
    result = lookingOut(arr, N, index, identificator, number);
 
    cout << result <<endl;
    
    system("pause");
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
22.06.2022, 09:43
Помогаю со студенческими работами здесь

Найти количество элементов матрицы, равных заданному числу
Написать программу, которая в матрице чисел A(N,M) находит все элементы, равные числу, введенному с клавиатуры. Подсчитать число таких...

Найти количество элементов матрицы, равных заданному числу, и их сумму
Задан двумерный массив n x m и величина К. Найти количество элементов, равных К и их сумму

написать программу, вычисляющую сумму элементов матрицы, не равных заданному числу к
Не могу написать программу, вычисляющую сумму элементов матрицы, не равных заданному числу к.Помогите, полжалуйста!

Подсчитать количество элементов матрицы равных заданному числу и вывести их индексы
Дано массив A действительных чисел и число a. Вывести этот массив на экран, подсчитать количество элементов, равных а, и вывести их индексы.

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


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru