С наступающим Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
Золушка_я
0 / 0 / 0
Регистрация: 13.06.2016
Сообщений: 79
1

Создать функцию, добавляющую столбец двухмерному динамическому массиву

01.10.2016, 23:14. Просмотров 1159. Ответов 1
Метки нет (Все метки)

Доброго времени суток, уважаемые форумчане! Помогите, пожалуйста, разобраться как написать функцию, удаляющую столбец двумерному динамическому массиву, в указанную пользователем позицию.
Знаю похожий пример, где удаляются столбы справа, но не пойму как это можно сделать на моем задании. Спасибо заранее за идеи и подсказки.
А вот пример программы, где с помощью функции удаляются столбцы справа. Ее основа годится для данного задания?
#include <iostream>
#include <cstdlib>
#include <random>
using std::cout;

int ** DeleleCol(int *** Array, int &x, int nDelCol);
int ** DeleleRow(int *** Array, int x, int &y, int nDelRow);

int main()
{
int n=5,m=4;
int ** Array;
Array=new int*[n];
for(int i=0;i<n;++i)
Array[i]=new int[m];


for(int i=0;i<m;++i){
for(int j=0;j<n;++j)
cout<<(Array[j][i]=rand()%100)<<"\t";
cout<<"\n";
}

cout<<"\n\n\n";
Array=DeleleRow(&Array,n,m,m-1);
for(int i=0;i<m;++i){
for(int j=0;j<n;++j)
cout<<Array[j][i]<<"\t";
cout<<"\n";
}

cout<<"\n\n\n";
Array=DeleleCol(&Array,n,n-1);
for(int i=0;i<m;++i){
for(int j=0;j<n;++j)
cout<<Array[j][i]<<"\t";
cout<<"\n";
}



for(int i=0;i<n;++i)
delete [] Array[i];
delete [] Array;
system("pause");
}




int ** DeleleCol(int *** Array, int &x, int nDelCol){
int ** tempArray=new int*[--x];

bool bFlag;
for(int i=0, bFlag=false;i<x;++i){
if(nDelCol==i) {bFlag=true; delete [] (*Array)[i];}
tempArray[i]=(bFlag)?(*Array)[i+1]*Array)[i];
}
delete [] (*Array);
return (*Array=tempArray);
}

int ** DeleleRow(int *** Array, int x, int &y, int nDelRow){
int * tempArray;
bool bFlag=false; --y;
for (int i=0;i<x;++i,bFlag=false){
tempArray=new int[y];
for(int j=0;j<y;++j){
if (nDelRow==j) {bFlag=true;}
tempArray[j]=(bFlag)?(*Array)[i][j+1]*Array)[i][j];
}
delete [] (*Array)[i];
(*Array)[i]=tempArray;
}
return *Array;
}
0
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.10.2016, 23:14
Ответы с готовыми решениями:

Написать функцию, добавляющую столбец двухмерного массива по указанному номеру
тема: Многомерные двухмерные массивы. Написать функцию, добавляющую столбец...

Как с помощью указателя пройтись по двухмерному массиву?
Всем привет. Подскажите плиз. Как с помощью указателя пройтись по двухмерному...

Поиск по динамическому массиву
Задан целочисленный двумерный массив a из n строк и m столбцов. Найти номер...

Доступ к динамическому массиву
Первый раз столкнулся с такой фигней. Что происходит? #include &lt;iostream&gt;...

Переход от статического к динамическому массиву
Есть некая структура some_struct. Необходимо перейти от статического массива...

1
_stanislav
Рука
418 / 380 / 207
Регистрация: 16.08.2014
Сообщений: 1,704
Завершенные тесты: 2
02.10.2016, 13:34 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
53
54
55
56
57
58
59
60
#inlcude <iostream>
 
int* ErasePosition(int* array_, size_t size, size_t index)
{
    int* t = new int[size - 1];
    size_t i;
 
    for (i = 0; i < index; i++) t[i] = array_[i];
    for (i = index + 1; i < size; i++) t[i - 1] = array_[i];
 
    delete[] array_;
    return t;
}
int** EraseColumn(int** array_,
    size_t sizeRow, size_t sizeColumn, size_t indexColumn)
{
    int** t = new int*;
    for (size_t i = 0; i < sizeRow; i++)
    {
        t[i] = new int[sizeColumn - 1];
        t[i] = ErasePosition(array_[i], sizeColumn, indexColumn);
    }
 
    return t;
}
 
int main(int argc, char* argv[] )
{
    const size_t size = 3;
    int count = 1;
    int** t = new int*;
    for (size_t i = 0; i < size; i++)
        t[i] = new int[size];
 
    for (size_t i = 0; i < size; i++)
        for (size_t j = 0; j < size; j++)
            t[i][j] = count++;
 
    for (size_t i = 0; i < size; i++)
    {
        for (size_t j = 0; j < size; j++)
            std::cout << t[i][j] << ' ';
 
        std::cout << std::endl;
    }
 
    std::cout << std::endl;
 
    t = EraseColumn(t, size, size, 0);
 
    for (size_t i = 0; i < size; i++)
    {
        for (size_t j = 0; j < size; j++)
            std::cout << t[i][j] << ' ';
 
        std::cout << std::endl;
    }
 
    return 0;
}
Добавлено через 15 минут
Первый код с ошибкой. Вот второй вариант.
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
#include <iostream>
 
int* ErasePosition(int* array_, size_t size, size_t index)
{
    int* t = new int[size - 1];
    size_t i;
 
    for (i = 0; i < index; i++) t[i] = array_[i];
    for (i = index + 1; i < size; i++) t[i - 1] = array_[i];
 
    delete[] array_;
    return t;
}
int** EraseColumn(int** array_,
    size_t sizeRow, size_t sizeColumn, size_t indexColumn)
{
    int** t = new int*[sizeRow];
    for (size_t i = 0; i < sizeRow; i++)
    {
        t[i] = new int[sizeColumn - 1];
        t[i] = ErasePosition(array_[i], sizeColumn, indexColumn);
    }
 
    return t;
}
 
int main(int argc, char* argv[] )
{
    const size_t size = 3;
    int count = 1;
    int** t = new int*[size];
    for (size_t i = 0; i < size; i++)
        t[i] = new int[size];
 
    for (size_t i = 0; i < size; i++)
        for (size_t j = 0; j < size; j++)
            t[i][j] = count++;
 
    for (size_t i = 0; i < size; i++)
    {
        for (size_t j = 0; j < size; j++)
            std::cout << t[i][j] << ' ';
 
        std::cout << std::endl;
    }
 
    std::cout << std::endl;
 
    t = EraseColumn(t, size, size, 0);
 
    for (size_t i = 0; i < size; i++)
    {
        for (size_t j = 0; j < size; j++)
            std::cout << t[i][j] << ' ';
 
        std::cout << std::endl;
    }
 
    delete[] *t;
    delete[] t;
 
    return 0;
}
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.10.2016, 13:34

Добавление памяти динамическому массиву
пытаюсь доканать динамические массивы (vector не предлагать, с ним все ок)....

Зачем нужен динамическому массиву указатель?
1) Зачем когда обьявляем массив нужен указатель? 2) почему если массив...

Нужен урок по одномерном и двумерному динамическому массиву
Нужен урок по одномерном и двумерному динамическому массиву


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

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