Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.82/11: Рейтинг темы: голосов - 11, средняя оценка - 4.82
96 / 96 / 21
Регистрация: 25.04.2012
Сообщений: 449

Двумерная динамическая матрица

09.11.2012, 16:44. Показов 2242. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
в общем помогите, надо написать двумерный массив(int) динамическим и пару функций к нему:
1. удаление столбца
2. удаление строки
3. добавление столбца
4. добавление строки

в исходном состоянии должен быть размер 1х1
пожалуйста!

Добавлено через 2 минуты
можно использовать stl\boost. векторы или через ручное выделение памяти(malloc там к примеру)

Добавлено через 5 минут
народ помогите, просто как добавлять к уже существующему массиву новые элементы через new и удалять конкретный элемент через delete я не умею, а через векторы не понятно(вектор вектора) и нужен пример для понимания, а найти нужное не могу!!!
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.11.2012, 16:44
Ответы с готовыми решениями:

двумерная матрица
Задача 1 Пусть есть двумерная матрица А произвольной размерности. Сформировать на ее основе вектор В элементы которого являются суммы...

Двумерная матрица без For
подскажите пожалуйста как ввести двумерную матрицй без цикла for, c одномерным массивом все понятно for(;;) { switch(Way) { ...

Двумерная матрица путей городов
Здравствуйте! Есть 9 городов. Kyzylorda, Atyrau, Almaty, Astana, Kostanai, Pavlodar, Semipalatinsk, Ust-Kamenagorsk, Uralsk....

11
Почетный модератор
7393 / 2639 / 281
Регистрация: 29.07.2006
Сообщений: 13,696
09.11.2012, 16:50
Вот пример "вектор вектора" Как считать матрицу из файла в двумерный вектор
1
96 / 96 / 21
Регистрация: 25.04.2012
Сообщений: 449
09.11.2012, 16:57  [ТС]
Цитата Сообщение от Vourhey Посмотреть сообщение
а как сделать функцию\метод класса для добавление нового столбца\строки?

т.е. если был размер 4*20 то по добавлению стал 5*20
или 4*21

Добавлено через 23 секунды
добавлять всегда в конец
0
Почетный модератор
7393 / 2639 / 281
Регистрация: 29.07.2006
Сообщений: 13,696
09.11.2012, 17:13
Строка - добавляешь в вектор новый вектор, push_back. Столбец, в каждый внутренний вектор пушбэчишь новые элементы.
0
96 / 96 / 21
Регистрация: 25.04.2012
Сообщений: 449
09.11.2012, 17:16  [ТС]
эту теорию мне понятно, но никак не получается это на коде помогите!
0
Почетный модератор
7393 / 2639 / 281
Регистрация: 29.07.2006
Сообщений: 13,696
09.11.2012, 17:17
Цитата Сообщение от Tiva Посмотреть сообщение
но никак не получается это на коде
Покажи, какой код уже написал.
0
96 / 96 / 21
Регистрация: 25.04.2012
Сообщений: 449
09.11.2012, 17:33  [ТС]
Цитата Сообщение от Vourhey Посмотреть сообщение
Покажи, какой код уже написал.
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 <iostream>
#include <vector>
#include <ctime>
using namespace std;
#define endline cout<<endl
#define ROWS 1
#define COLS 1
using namespace std; 
int main()
{
    int count=0;
    srand(time(NULL));
    
    vector <vector<int> > matr(ROWS, vector<int>(COLS));
    for ( int i = 0; i < ROWS; ++i )
        for ( int j = 0; j < COLS; ++j )
        {
            matr[i][j] = count;
            count++;
        }
    
    cout << "Matrix:" << endl;
    for ( vector< vector<int> >::const_iterator i = matr.begin(); i != matr.end(); ++i )
    {
        copy(i->begin(), i->end(), ostream_iterator<int>(cout, "\t")); 
        cout<<endl;
    }
    endline;
    
    matr.push_back(vector<int>(matr.size())); //тут добавление чего? строки?
    
 
    for ( vector< vector<int> >::const_iterator i = matr.begin(); i != matr.end(); ++i )
    {
        copy(i->begin(), i->end(), ostream_iterator<int>(cout, "\t"));    
        cout<<endl;
    }
    endline;
    
    vector<int> new_row(5);   
    matr.push_back(new_row);//добавление чего? столбцов?
 
//==
    for ( int i = 0; i < matr.size(); ++i )
        for ( int j = 0; j < matr[i].size(); ++j )
        {
            matr[i][j] = count;
            count++;
        }
//==
 
 
    for ( vector< vector<int> >::const_iterator i = matr.begin(); i != matr.end(); ++i )
    {
        copy(i->begin(), i->end(), ostream_iterator<int>(cout, "\t"));    
        cout<<endl;
    }
}
результат:
Code
1
2
3
4
5
6
7
8
9
10
Matrix:
0
 
0
0
 
1
2
3       4       5       6       7
Для продолжения нажмите любую клавишу . . .
т.е. он добавил не 5 столбцов, а 5 элементов в 3ю строку, т.е. нарушилась прямоугольность массива.
мне бы нормальные пару функций\методов
0
Почетный модератор
7393 / 2639 / 281
Регистрация: 29.07.2006
Сообщений: 13,696
09.11.2012, 18:13
Цитата Сообщение от Tiva Посмотреть сообщение
мне бы нормальные пару функций\методов
Что значит "нормальные"?

Добавлено через 1 минуту
У тебя с самого начала какая-то матрица непонятная выводится...

Добавлено через 3 минуты
Цитата Сообщение от Tiva Посмотреть сообщение
matr.push_back(new_row);//добавление чего? столбцов?
Ты пишешь код и сам не знаешь, что пишешь? Почему переменная обзывается new_row? )))

Добавлено через 30 минут
Например, добавление можно сделать примерно так:
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
#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>
 
typedef std::vector<std::vector<int>>::iterator matrix_iterator;
 
class Matrix
{
private:
    std::vector<std::vector<int>> v;
public:
    Matrix()
    {
        v.push_back(std::vector<int>(1));
    }
 
    void AddRow()
    {
        v.push_back(std::vector<int>(v.back().size()));
    }
 
    void AddColumn()
    {
        for(matrix_iterator it = v.begin(); it != v.end(); ++it)
            it->push_back(0);
    }
 
    void PrintOut(std::ostream& OutStream)
    {
        for(matrix_iterator it = v.begin(); it != v.end(); ++it)
        {
            std::copy(it->begin(), it->end(), std::ostream_iterator<int>(OutStream, " "));
            OutStream<<std::endl;
        }
    }
};
 
int main()
{
    Matrix a;
    a.AddRow();
    a.AddRow();
    a.AddRow();
    a.AddColumn();
    a.AddColumn();
    a.PrintOut(std::cout);
 
    system("pause");
}
Вывод:
0 0 0
0 0 0
0 0 0
0 0 0
Ну а удаление, верю, ты добавишь сам.
1
96 / 96 / 21
Регистрация: 25.04.2012
Сообщений: 449
09.11.2012, 19:11  [ТС]
Цитата Сообщение от Vourhey Посмотреть сообщение
Ну а удаление, верю, ты добавишь сам.
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
#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>
using namespace std;
typedef vector<vector<int>>::iterator matrix_iterator;
/*
Row - Subject - строки
Columns - Object - столбцы
 
*/
class Matrix
{
private:
    vector<vector<int>> v;
public:
    Matrix();
    void AddSubject();
    void AddObject();
    void DelSubject();
    void DelObject();
    void PrintOut(ostream& OutStream);
};
void Matrix::DelObject()
{
    matrix_iterator iterlvl2;
    vector< int >::iterator iterlvl1;
        for (iterlvl2=v.begin();iterlvl2 != v.end();iterlvl2++) {
            iterlvl1 = (*iterlvl2).begin();
            (*iterlvl2).pop_back(); 
        }
}
void Matrix::DelSubject()
{
    v.pop_back();
}
Matrix::Matrix()
{
    v.push_back(vector<int>(1));
}
void Matrix::AddSubject()
{
    v.push_back(vector<int>(v.back().size()));
}
void Matrix::AddObject()
{
    for(matrix_iterator it = v.begin(); it != v.end(); ++it)
        it->push_back(0);
}
void Matrix::PrintOut(ostream& OutStream)
{
    for(matrix_iterator it = v.begin(); it != v.end(); ++it)
    {
        copy(it->begin(), it->end(), ostream_iterator<int>(OutStream, " "));
        OutStream<<endl;
    }
}
int main()
{
    Matrix a;
    a.AddObject();
    a.AddObject();
    a.AddObject();
 
    a.AddSubject();
    a.AddSubject();
    a.AddSubject();
    a.AddSubject();
    a.PrintOut(cout);
    cout<<"after\n\n";
    a.DelSubject();
    a.PrintOut(cout);
 
    cout<<"after\n\n";
    a.DelObject();
    a.PrintOut(cout);
    
}
удаление последних столбцов\строк написал, да.
а как сделать удаление i-го столбца\строки? как передаваемое число в метод сопоставить с итератором? не получается
0
Почетный модератор
7393 / 2639 / 281
Регистрация: 29.07.2006
Сообщений: 13,696
09.11.2012, 20:01
Цитата Сообщение от Tiva Посмотреть сообщение
как передаваемое число в метод сопоставить с итератором? не получается
Вектор поддерживает индексацию.
0
96 / 96 / 21
Регистрация: 25.04.2012
Сообщений: 449
09.11.2012, 20:10  [ТС]
Цитата Сообщение от Vourhey Посмотреть сообщение
Вектор поддерживает индексацию.
что-то я или совсем туплю
или
C++
1
2
3
4
void Matrix::DelSubject(int n)
{
    v.erase(n);
}
не компилится ((
0
Почетный модератор
7393 / 2639 / 281
Регистрация: 29.07.2006
Сообщений: 13,696
09.11.2012, 20:17
C++
1
v.erase(v.begin() + n);
Добавлено через 18 секунд
Цитата Сообщение от Tiva Посмотреть сообщение
не компилится ((
Так и не должно
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.11.2012, 20:17
Помогаю со студенческими работами здесь

Двумерная матрица из среднего арифметического
Здравствуйте. Собственно само задание звучит так: нужно составить матрицу nxn и с ее помощью создать другую, которая будет заполнена...

Двумерная матрица и выражения . Не могу разобраться
Всем доброго времени суток,не могу разобраться с задачей. Особую сложность вызывает написание выражений , в частности модуль . Уж шибко...

Двумерная матрица. Найти количество похожих строк.
Дана целочисленная матрица размера M x N. Различные строки матрицы назовем похожими, если попарно совпадают больше половины чисел,...

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

Двумерная матрица на С++ (найти все парные элементы в двумерном массиве и сложить их)
Добрый вечер! Подскажите пожалуйста каким образом можно реализовать следующую задачу. Необходимо найти все парные элементы в двумерном...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru