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

Определить количество столбцов матрицы, не содержащих ни одного нулевого элемента

07.11.2015, 12:53. Показов 11401. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дана целочисленная прямоугольная матрица.Определить количество столбцов, не содержащих ни одного нулевого элемента. Помогите составить программу...
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.11.2015, 12:53
Ответы с готовыми решениями:

Определить количество столбцов матрицы, не содержащих ни одного нулевого элемента
Здравствуйте! Помогите , пожалуйста, решить задачу. Вот текст:1) Дана целочисленная прямоугольная матрица. Определить количествло столбцов,...

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

Определить количество столбцов матрицы, не содержащих ни одного нулевого элемента
Здравствуйте! Помогите , пожалуйста, решить задачу. Вот текст:1) Дана целочисленная прямоугольная матрица. Определить количествло столбцов,...

7
Wanna be serious
 Аватар для Bespridelschic
587 / 474 / 186
Регистрация: 31.07.2013
Сообщений: 1,693
07.11.2015, 13:29
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
#include <iostream>
 
int main() {
    setlocale(LC_ALL, "Russian");
    int n, m;
    std::cout << "Введите количество строк: ";
    std::cin >> n;
    std::cout << "Введите количество стробцов: ";
    std::cin >> m;
    int **a = new int *[n], i, j;
    for (i = 0; i < n; i++)
    {
        a[i] = new int[m];
    }
    std::cout << "Введите " << n*m << " элементов:\n";
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < m; j++)
        {
            std::cout << "a[" << i + 1 << "." << j + 1 << "]: ";
            std::cin >> a[i][j];
        }
    }
    int temp = 0, count = 0;
    for (j = 0; j < m; j++)
    {
        for (i = 0; i < n; i++)
        {
            if (a[i][j] != 0)
            {
                temp++;
            }
        }
        if (temp == m)
        {
            count++;
        }
        temp = 0;
    }
    std::cout << "Количество столбцов не содержащих не одного нулевого элемента = " << count << std::endl;
    system("Pause >> 0");
    return 0;
}
2
12 / 1 / 0
Регистрация: 19.11.2014
Сообщений: 42
07.11.2015, 14:13  [ТС]
А как вывести полученную матрицу для наглядности на экран, чтобы было видно где столбцы с нулями?
0
Wanna be serious
 Аватар для Bespridelschic
587 / 474 / 186
Регистрация: 31.07.2013
Сообщений: 1,693
07.11.2015, 15:15
Добавьте в 23 строчку данный фрагмент:
C++
1
2
3
4
5
6
7
8
9
std::cout << std::endl;
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < m; j++)
        {
            std::cout << std::setw(3) << a[i][j];
        }
        std::cout << "\n\n";
    }
А в самом начале подключите заголовочный файл
C++
1
#include <iomanip>
1
12 / 1 / 0
Регистрация: 19.11.2014
Сообщений: 42
08.11.2015, 10:04  [ТС]
Что-то не работает, он ищет по всей матрице 0, если 0 нет, то пишет количество всех столбцов, а если 0 есть, то пишет таких столбцов нет...

Добавлено через 11 минут
Получилось вот так...
C++ (Qt)
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
#include <iostream>
#include <cmath>
#include <iomanip>
 
using namespace std;
int main()
{ setlocale(LC_ALL, "Russian");
 
int array[100][100];
int k=0; 
int k1=0; 
int n; // переменная для количества строк
int m; //переменная для количества столбцов
int i; 
int j;
cout<<"Введите кол. строк"<<endl;
        cin>>n;
cout<<"Введите кол. столбцов"<<endl;
        cin>>m;
cout<<"Введите элементы массива"<<endl;
 for (i=0; i<n; i++)
    {
        for (j=0; j<m; j++)
          { 
                    cin>>array[i][j];
          }
    }
cout<<endl;
  for (i = 0; i < n; i++)
    {
        for (j = 0; j < m; j++)
        {
            std::cout << std::setw(3) << array[i][j];
        }
        std::cout << "\n\n";
    }
  for (j=0; j<n; j++)
  {    
        for (i=0; i<m; i++)
        {         
            if (array[j]==0)
             {
                k1++;
             }
        }
      if (!k1)
        {
          k++;
        }
        k1=0;
   }  
    cout<<"Количество столбцов не содержащих нулевой элемент "<<k<<endl;
    system ("pause");
    return 0;
  }
1
Wanna be serious
 Аватар для Bespridelschic
587 / 474 / 186
Регистрация: 31.07.2013
Сообщений: 1,693
08.11.2015, 10:52
Ну давайте протестируем, тест исходника который написал я:






Протестируем вашу при равных условиях:






По представленным условиям задачи мой код работает корректно. В вашем происходит ошибка. Опишите вашу проблему, что бы я мог разобраться что именно происходит не так.
1
0 / 0 / 0
Регистрация: 28.01.2021
Сообщений: 4
28.01.2021, 16:45
Bespridelschic, Приветствую!

Есть такая задача:

Дана целочисленная прямоугольная матрица. Определить:
1) количество строк, не содержащих ни одного нулевого элемента;
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
#include <iostream>
#include <iomanip>
 
int main() {
    setlocale(LC_ALL, "Russian");
    int n, m;
    std::cout << "Введите количество строк: ";
    std::cin >> n;
    std::cout << "Введите количество столбцов: ";
    std::cin >> m;
    int **a = new int *[n], i, j;
    for (i = 0; i < n; i++)
    {
        a[i] = new int[m];
    }
    std::cout << "Введите " << n*m << " элементов:\n";
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < m; j++)
        {
            std::cout << "a[" << i + 1 << "." << j + 1 << "]: ";
            std::cin >> a[i][j];
        }
    }
    std::cout << std::endl;
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < m; j++)
        {
            std::cout << std::setw(3) << a[i][j];
        }
        std::cout << "\n\n";
    }
    int temp = 0, count = 0;
    for (j = 0; j < m; j++)
    {
        for (i = 0; i < n; i++)
        {
            if (a[i][j] != 0)
            {
                temp++;
            }
        }
        if (temp == n)
        {
            count++;
        }
        temp = 0;
    }
    std::cout << "Количество строк не содержащих не одного нулевого элемента = " << count << std::endl;
    return 0;
}
Добавлено через 45 минут
Bespridelschic, Update!

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

Помогите пожалуйста добить доп.условия:

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
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <memory.h>
 
#define N 10
 
void swap(int& n1, int& n2);
 
int main()
{
    int** X = new int*[N];
    memset((void*)X, 0x00, 4 * N);
 
    for (int i = 0; i < N; i++)
    {
        X[i] = new int[N];
        for (int j = 0; j < N; j++)
        {
            X[i][j] = rand() % 9 + 1;
            printf("%d ",X[i][j]);
        }
 
        printf("\n");
    }
 
    int x = 0, *Y = new int[N * N];
    for (int t1 = 0; t1 < N; t1++)
        for (int t2 = 0; t2 < N; t2++)
            Y[x++] = X[t1][t2];
 
    for (int k = 0; k < N * N; k++)
    {
        int max = k;
        for (int m = k+1; m < N * N; m++)
            max = Y[m] > Y[max] ? m : max; 
        swap(Y[k],Y[max]);
    }
 
    bool found = false; int d = 0;
    while (d < N * N && !found)
    {
        int count = 0;
        for (int v1 = 0; v1 < N; v1++)
            for (int v2 = 0; v2 < N; v2++)
                if (X[v1][v2] == Y[d]) count++;
        found = (count > 1) ? 1 : 0; d++;
    }
 
    printf("\nMax = %d\n",Y[d]);
 
    getch();
 
    return 0;
}
 
void swap(int& n1, int& n2)
 { int _tn = n1; n1 = n2; n2 = _tn; }
0
Wanna be serious
 Аватар для Bespridelschic
587 / 474 / 186
Регистрация: 31.07.2013
Сообщений: 1,693
28.01.2021, 20:38
Sneedjik, ну Вы конечно раскопали тему, которой более 5 лет уже. Я с тех самых пор на плюсах и не писал

Тот код что я выкладывал ранее поддерживает динамичный ввод. Для использования средств генерации рандомных чисел, можете ознакомиться с данным руководством.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.01.2021, 20:38
Помогаю со студенческими работами здесь

Определить количество столбцов матрицы, не содержащих ни одного нулевого элемента
Помогите еще с одной программой пожалуйста Дана прямоугольная матрица Определить: 1. количество столбцов, не содержащих ни...

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

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

Определить количество столбцов матрицы, не содержащих ни одного нулевого элемента
1. Условные операторы. а.) Вычислить значения функциии при заданных условиях. Подготовить тесты (число тестов...

Определить количество столбцов матрицы не содержащих ни одного нулевого элемента
Дана целочисленная прямоугольная матрица. Определить количество столбцов, не содержащих ни одного нулевого элемента. В теме должна быть...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru