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

Удалить из матрицы строки и стольбцы

02.11.2011, 17:19. Показов 764. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дана прямоугольная матрица,уплотнить её,удалив из неё строки и столбцы заполненные нулями.

Подскажите как удалить где все нули,я знаю как сделать проверку на равность нулю каждого эелемента и переписать в новую(затем вывести),а как всю строчку не могу понять

Добавлено через 3 часа 38 минут
Еще не решена
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
02.11.2011, 17:19
Ответы с готовыми решениями:

Удалить строки динамической матрицы, начиная со строки К1 и до строки К2
Сформировать динамический двумерный массив, заполнить его случайными числами и удалить строки, начиная со строки К1 и до строки К2 вот...

Найти сумму элементов каждой строки матрицы и удалить строки, содержащую максимальный элемент
Дана матрица А. Ввести элементы массива с помощью генератора случайных чисел в интервале . Вывести матрицу на экран Найти: • найти...

Удалить строки, для которых в матрице есть повтрряющиеся строки. Вывести на экран измененное состояние матрицы
помогите с написанием программки. Дана целочисленная матрица А, состоящая из М строк и N столбцов. Удалить строки, для которых в...

3
 Аватар для OstapBender
594 / 532 / 76
Регистрация: 22.03.2011
Сообщений: 1,585
02.11.2011, 17:27
допустим, сделать 2 массива к которых будут индексы строк и стлб. в кот. все 0.
создать новую матрицу и НЕ переносить туда стлб. и строки с соотв. индексами.
0
1 / 1 / 0
Регистрация: 19.02.2010
Сообщений: 32
02.11.2011, 17:56  [ТС]
Не понял =)
0
Злой няш
 Аватар для I2um1
2136 / 1505 / 565
Регистрация: 05.04.2010
Сообщений: 2,881
02.11.2011, 18:33
C1keu, вот алгоритм, который предложил OstapBender:
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
    // Определение границ матрицы
    size_t n, m;
    _tprintf(_T("Количество строк = "));
    _tscanf(_T("%d"), &n);
    _tprintf(_T("Количество столбцов = "));
    _tscanf(_T("%d"), &m);
 
    // Заполнение матрицы
    size_t *matrix = new size_t[n * m];
    for (size_t i = 0; i < n; ++i)
        for (size_t j = 0; j < m; ++j)
        {
            _tprintf(_T("Матрица[%d][%d] = "), i, j);
            _tscanf(_T("%d"), &matrix[i * m + j]);
        }
 
    // Определяем то, что надо уплотнить
    size_t *row = new size_t[n], *column = new size_t[m];
    memset(row, 0, n * sizeof(size_t));
    memset(column, 0, m * sizeof(size_t));
    size_t count_row = 0, count_column = 0;
    for (size_t i = 0; i < n; ++i)
    {
        bool flag = true;
        for (size_t j = 0; j < m; ++j)
            if (matrix[i * m + j])
            {
                flag = false;
                break;
            }
        row[i] = flag ? 1 : 0;
        count_row += flag ? 1 : 0;
    }
    for (size_t i = 0; i < m; ++i)
    {
        bool flag = true;
        for (size_t j = 0; j < n; ++j)
            if (matrix[j * m + i])
            {
                flag = false;
                break;
            }
        column[i] = flag ? 1 : 0;
        count_column += flag ? 1 : 0;
    }
 
    // Уплотнение матрицы
    size_t rn = n - count_row, rm = m - count_column;
    size_t *result = new size_t[rn * rm];
    for (size_t i = 0, ri = 0; i < n; ++i)
        for (size_t j = 0, rj = 0; j < m; ++j)
            if (!row[i] && !column[j])
            {
                result[ri * rm + rj] = matrix[i * m + j];
                rj++;
                if (rj >= rm)
                {
                    rj = 0;
                    ri++;
                }
            }
 
    // Вывод результата
    for (size_t i = 0; i < rn; ++i)
    {
        for (size_t j = 0; j < rm; ++j)
            _tprintf(_T("%d "), result[i * rm + j]);
        _tprintf(_T("\n"));
    }
 
    // Очистка памяти
    delete[] result;
    delete[] column;
    delete[] row;
    delete[] matrix;
P.S. Возможны незначительные ошибки - проверял всего на пару входных данных.
P.S.S. Реализацию немного упростил - в оригинале было не так.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.11.2011, 18:33
Помогаю со студенческими работами здесь

Удалить из матрицы А (7×5) все строки, сумма элементов которых четна, а из матрицы В (6×8) – строки, сумма эле
2. Удалить из матрицы А (7×5) все строки, сумма элементов которых четна, а из матрицы В (6×8) – строки, сумма элементов которых...

Удалить из матрицы А (7×5) все строки, сумма элементов которых четна, а из матрицы В (6×8) – строки, сумма эле
Удалить из матрицы А (7×5) все строки, сумма элементов которых четна, а из матрицы В (6×8) – строки, сумма элементов которых...

Удалить из матрицы нулевые строки
Господа уважаемые программеры! Пожалуйста помогите доделать детскую прогу. Имеется матрица NxM элементов. Нужно удалить методом...

Удалить из матрицы все строки с A до B
Ребята, здравствуйте! Не могу решить вот эту задачу вообще что-то... Помогите, пожалуйста! Буду очень признателен!

Удалить из матрицы A все строки, сумма элементов которых четна, а из матрицы B – строки, сумма элементов которых нечетна(функции)
Удалить из матрицы А (7х5) все строки, сумма элементов которых четна, а из матрицы В (6х8) – строки, сумма элементов которых нечетна.


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru