Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
C1keu
1 / 1 / 0
Регистрация: 19.02.2010
Сообщений: 32
#1

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

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

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

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

Добавлено через 3 часа 38 минут
Еще не решена
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.11.2011, 17:19     Удалить из матрицы строки и стольбцы
Посмотрите здесь:

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

Удалить все строки матрицы, которые содержат нули - C++
Дана квадратная матрица целых числе N*N(N-константа), заданная случайным образом, числами из промежутка от -10 до 5. Удалить все строки...

Удалить из каждой строки матрицы все элементы, величина которых находится в отрезке (a,b) - C++
удалить из каждой строки двумерного массива все элементы ,величина которых находится в отрезке (a,b), а освободишихся в концах строк...

Удалить все строки матрицы, в которых среднее арифметическое элементов является двузначным числом - C++
В двумерном массиве, элементы которого целые числа, произвести следующие действия, удалить все строки, в которых среднее арифметическое...

Определить, что все элементы строки первой матрицы больше соответствующих элементов строки второй матрицы - C++
Помогите,пожалуйста,с решением массивов в с++.надо в статическом и динамическом варианте. Даны две целочисленные квадратные матрицы...

Удалить из строки каждую пару символов '!?' и удалить некоторые символы - C++
помогите решить задачу, пожалуйста. используя scanf для чтения. Удалить из строки каждую пару символов '!?', подсчитать количество...

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
OstapBender
583 / 521 / 35
Регистрация: 22.03.2011
Сообщений: 1,585
02.11.2011, 17:27     Удалить из матрицы строки и стольбцы #2
допустим, сделать 2 массива к которых будут индексы строк и стлб. в кот. все 0.
создать новую матрицу и НЕ переносить туда стлб. и строки с соотв. индексами.
C1keu
1 / 1 / 0
Регистрация: 19.02.2010
Сообщений: 32
02.11.2011, 17:56  [ТС]     Удалить из матрицы строки и стольбцы #3
Не понял =)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.11.2011, 18:33     Удалить из матрицы строки и стольбцы
Еще ссылки по теме:

Найти среднее арифметическое элементов каждой строки матрицы Q (lm) и отнять его от элементов этой строки. размер матрицы 7х7.заранее спасибо - C++
Найти среднее арифметическое элементов каждой строки матрицы Q (lm) и отнять его от элементов этой строки.. размер матрицы 7х7.заранее...

Строки. Удалить из строки S1 последнюю подстроку, совпадающую с S2 - C++
Помогите решить задачу Даны строки S1 и S2. Удалить из строки S1 последнюю подстроку, совпадающую с S2. Если совпадающих подстрок...

Указать номер строки, максимально удаленной от первой строки заданной матрицы - C++
Задание: Расстояние между k-й и 1-й строками квадратной матрицы А опеределяется как r = сумма от j=1 до N от (abs(akj)*abs(a1j)). Указать...

Упорядочить строки матрицы лексикографически по неубыванию первых k элементов строки. - C++
Помогите решить задачу, пожалуйста Упорядочить строки матрицы D ( m, n) лексикографически по неубыванию первых k элементов строки. ...


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

Или воспользуйтесь поиском по форуму:
I2um1
Злой няш
1399 / 1097 / 142
Регистрация: 05.04.2010
Сообщений: 1,949
02.11.2011, 18:33     Удалить из матрицы строки и стольбцы #4
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. Реализацию немного упростил - в оригинале было не так.
Yandex
Объявления
02.11.2011, 18:33     Удалить из матрицы строки и стольбцы
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru